如何处理 vObject 在处理 UTF-8 字符时检查字符串是否有效



如何使用vObject检查字符串是否有效?

是否有一些额外的方法或通用方法可以尝试和捕获?

现在我这样做如下:

 try:
            vobj = vobject.readOne(vcard_readable)
 except Exception as e:
            error_message = {
                "valid": False,
                "reason": "Invalid vCardn{0}".format(e)}

如何使用VOBJECT处理Unicode?

您当前的代码工作正常,但通常您不想捕获Exception因为这会掩盖代码中的其他错误。 例如,如果我把你的代码片段放在一个文件中,然后运行它......即使我尚未导入vobject模块,我也没有收到任何错误消息。 这是因为该代码实际上引发了一个NameError

Traceback (most recent call last):
  File "foo.py", line 2, in <module>
    vobj = vobject.readOne(vcard_readable)
NameError: name 'vobject' is not defined

但是,因为您捕获了所有异常,所以您隐藏了它。 更好的方法是仅捕获您希望从vobject模块接收的特定异常,并让其他异常正常渗透。

对于vobject,它引发的所有异常都将是vobject.base.VObjectError的子类,所以下面的代码就足够了:

 try:
            vobj = vobject.readOne(vcard_readable)
 except vobject.base.VObjectError as e:
            error_message = {
                "valid": False,
                "reason": "Invalid vCardn{0}".format(e)}
 vcard = put.get('vcard')
            try:
                vcard_readable = base64.decodestring(vcard)
                quoted_printable_vcard = quopri.encodestring(vcard_readable)
                vobj = vobject.readOne(quoted_printable_vcard)
            except UnicodeEncodeError as e:  # case of bad encoding
                error_message = {
                    "valid": False,
                    "reason": "Invalid vCardn{0}".format(e)}
                return HttpResponse(json.dumps(error_message), status=200)
            except vobject.base.VObjectError as e2:  # case of invalid vcard
                error_message = {
                    "valid": False,
                    "reason": "Invalid vCard formatn{0}".format(e2)}
                return HttpResponse(json.dumps(error_message), status=200)
            except:
                error_message = {
                    "valid": False,
                    "reason": "Invalid vCard."}
                return HttpResponse(json.dumps(error_message), status=200)

还行。我解决了。要使vobject使用 UNICODE (UTF-8),需要使用:

quoted printable encoding. - 下面的示例:

>>> s = "gżegżółka"
>>> s
'gxc5xbcegxc5xbcxc3xb3xc5x82ka'
>>> import quopri
>>> quopri.encodestring(s)
'g=C5=BCeg=C5=BC=C3=B3=C5=82ka'

最新更新