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/

10-09 20:18
查看更多