JSON对象被打印到我的syslog文件中。我需要从日志中提取字符串并将其转换为JSON。我提取“{
”和“}
”之间的字符串没有任何问题,但是某些字符串中包含转义字符,这会导致json.loads
失败
这是问题所在:
>>> import json
>>> resp = '{"from_hostname": {"value": "mysite.edu\"", "value2": 0, "value3": 1}}'
>>> json.loads(resp)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/__init__.py", line 338, in loads
return _default_decoder.decode(s)
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 365, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/decoder.py", line 381, in raw_decode
obj, end = self.scan_once(s, idx)
ValueError: Expecting , delimiter: line 1 column 41 (char 40)
>>> resp[40]
'"'
>>> resp[41]
','
>>> resp[39]
'"'
>>>
当
json
看到\"
时,我猜它只看到"
并假定字符串已结束,并且抛出定界符错误。我尝试用
\"
替换\\"
,但这似乎不起作用。注意:
\"
可以出现在字符串的开头或结尾或中间。我该如何工作?
最佳答案
如果\"
可能出现在您的字符串中,则必须使用以下命令转义\
和"
import json
resp = '{"from_hostname": {"value": "mysite.edu\\\"", "value2": 0, "value3": 1}}'
print(json.loads(resp))
它打印
{u'from_hostname': {u'value3': 1, u'value2': 0, u'value': u'mysite.edu"'}}
这是您问题的正确解释吗?
关于Python-将带有转义符的字符串转换为json,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/34888467/