[英]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.