首页 > 解决方案 > 如何使用python从字符串列表中删除生成的json旁边的双引号

问题描述

我的 JSON 是输入 json { 'debug': None, 'traceback': None, 'rsname': None, 'resolutionStatus': 0, 'algorithmResponseInfo': None, 'rules': "['check']", 'rulesResults ': '-RNCID Found', 'mmlCommand': 'tk_com', 'KMmmlCommand': 'cat "tk"', 'similarityScore': {'similarityUI': 100 }} 这是无效的,我想将其转换为有效我想""使用 python 从规则列(列表)中删除双引号和单反斜杠。我已经尝试了以下方法,但没有奏效-

data = data.replace('"',"\\'").replace("'", '"').replace("True","true").\
             replace("None","null").replace("False","false").replace("\'", '"').replace("'", '"')

data = json.loads(data)

输出为 - data = { "debug": null, "traceback": null, "rsname": null, "resolutionStatus": 0, "algorithmResponseInfo": null, "rules": \ "["check"]", " rulesResults": "-RNCID Found", "mmlCommand": "tk_com", "KMmmlCommand": "cat "tk"", "similarityScore": { "similarityUI": 100 }}

但我需要删除额外的反斜杠和预期的双引号是-data = {“debug”:null,“traceback”:null,“rsname”:null,“resolutionStatus”:0,“algorithmResponseInfo”:null,“rules”: [“检查”],“rulesResults”:“找到-RNCID”,“mmlCommand”:“tk_com”,“KMmmlCommand”:“cat“tk””,“similarityScore”:{“similarityUI”:100 }}

标签: jsonpython-3.x

解决方案


你所拥有的根本不是 JSON,而是 Python 文字。只是 Python 的字面量与 JSON 非常相似。转换它的安全方法是使用 ast.literal_eval:

from ast import literal_eval
import json
data = (
    "{ 'debug': None, 'traceback': None, 'rsname': None,"
    " 'resolutionStatus': 0, 'algorithmResponseInfo': None, "
    "'rules': \"['check']\", 'rulesResults': '-RNCID Found', "
    "'mmlCommand': 'tk_com', 'KMmmlCommand': 'cat \"tk\"',"
    " 'similarityScore': {'similarityUI': 100 }}"
python_doc = literal_eval(data)
json_str = json.dumps(python_doc)

# {"debug": null, "traceback": null, "rsname": null, "resolutionStatus": 0,
# "algorithmResponseInfo": null, "rules": "['check']",
#  "rulesResults": "-RNCID Found", "mmlCommand": "tk_com",
#  "KMmmlCommand": "cat \"tk\"", "similarityScore": {"similarityUI": 100}}
print(json_str)

不安全的替代方法literal_evaleval. 问题eval在于,如果攻击者可以控制输入,他们就可以导致任意代码运行。


推荐阅读