我已经用字典的值将变量'a'定义为字符串。 尝试将该字符串加载为json时出错。
>>> a = '{"key":"^~\\&"}'
>>> data = json.loads(a, object_pairs_hook=OrderedDict)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/__init__.py", line 352, in loads
return cls(encoding=encoding, **kw).decode(s)
File "/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 364, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 380, in raw_decode
obj, end = self.scan_once(s, idx)
ValueError: Invalid \escape: line 1 column 9 (char 8)
>>>
有没有办法做到这一点
答案 0 :(得分:1)
使用原始字符串可避免python“吃”一个反斜杠,然后再加载作品:
>>> a = r'{"key":"^~\\&"}'
>>> print(json.loads(a))
{'key': '^~\\&'}
由于字符串的表示,反斜杠仍然加倍,但是在这里:
>>> print(json.loads(a)["key"])
^~\&
工作正常
当然,如果您的数据已经包含有问题的字符串,则原始字符串将无济于事。在这种情况下,请使用replace
:
>>> a = '{"key":"^~\\&"}' # wrong
>>> a = a.replace("\\","\\\\")
>>> print(json.dumps(json.loads(a)))
{"key": "^~\\&"}
也可以。
答案 1 :(得分:0)
在处理包含反斜杠的字符串时,应始终使用原始字符串文字:
(只需将r
放在字符串之前)
>>> a = r'{"key":"^~\\&"}'
>>> data = json.loads(a, object_pairs_hook=OrderedDict)