[英]Parsing json string representation with delimited double quote marks and booleans in python
这似乎很基本,以至于我不敢相信我还没有找到一个简单的解决方案。 我正在尝试评估 python 中的 json 字符串表示形式,其中包含反斜杠分隔的双引号和 boolean 值。
例如s = "{\"data\":true}"
。
这是 javascript 中的有效 json 作为JSON.parse("{\"data\":true}")
返回一个有效的 ZA8CFDE63311C4BEB26AC
我尝试了多种方法,但都没有提供 json object 的 Python 化字符串表示的所需解决方案:
使用eval(s)
给出NameError: name 'true' is not defined
。
使用ast.literal_eval(s)
给出ValueError: malformed string
。
使用json.dumps(json.loads(s))
返回相同格式的字符串。
我想要的 output 是"{'data':True}"
,因为我的 neo4j 数据库无法将\
识别为用于存储目的的分隔符,因此在尝试存储初始格式时会产生错误。 我试图避免用'
硬替换\"
或用True
替换true
,因为必须有更好、更快和更简单的解决方案来解决这个问题。
使用json.loads :
import json
result = str(json.loads("{\"data\":true}"))
print(result, type(result))
Output
{'data': True} <class 'str'>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.