我有一个文件,其中包含:
{
"name": "HOSTNAME_HTTP",
"description": "Custom hostname for http service route. Leave blank for default hostname, e.g.: \u003capplication-name\u003e-\u003cproject\u003e.\u003cdefault-domain-suffix\u003e"
}
当我使用以下方式打开文件时:
with open('data.txt', 'r') as file:
data = file.read()
我将其传递给 json.loads 并将数据中的内容替换为:
<application>...</application>
如何防止 python json.loads 弄乱内容中的编码?
最佳答案
您可以使用这样的解决方法来转义 unicode 序列:
>>> obj = json.loads(data.replace('\\', '\\\\'))
>>> obj
{'name': 'HOSTNAME_HTTP',
'description': 'Custom hostname for http service route. Leave blank for default hostname, e.g.: \\u003capplication-name\\u003e-\\u003cproject\\u003e.\\u003cdefault-domain-suffix\\u003e'}
完成修改后:
>>> print(json.dumps(obj).replace('\\\\', '\\'))
{"name": "HOSTNAME_HTTP", "description": "Custom hostname for http service route. Leave blank for default hostname, e.g.: \u003capplication-name\u003e-\u003cproject\u003e.\u003cdefault-domain-suffix\u003e"}
如果您希望文件中存在其他反斜杠,那么使用正则表达式会更安全:
import re
from_pattern = re.compile(r'(\\u[0-9a-fA-F]{4})')
to_pattern = re.compile(r'\\(\\u[0-9a-fA-F]{4})')
def from_json_escaped(path):
with open(path, 'r') as f:
return json.loads(from_pattern.sub(r'\\\1', f.read()))
def to_json_escaped(path, obj):
with open(path, 'w') as f:
f.write(to_pattern.sub(r'\1', json.dumps(obj)))
关于python - 如何防止 python json.loads() 不必要地解码字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59524991/