当前位置: 首页 > 知识库问答 >
问题:

使用json保存UTF-8文本。转储为UTF-8,而不是\u转义序列

须敏学
2023-03-14

示例代码(在REPL中):

import json
json_string = json.dumps("ברי צקלה")
print(json_string)

输出:

"\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4"

问题是:它不是人类可读的。我的(聪明的)用户希望用JSON转储来验证甚至编辑文本文件(我宁愿不使用XML)。

有没有办法将对象序列化为UTF-8 JSON字符串(而不是\uXXXX)?

共有3个答案

武骁
2023-03-14

Pieters的Python 2解决方法在边缘情况下失败:

d = {u'keyword': u'bad credit  \xe7redit cards'}
with io.open('filename', 'w', encoding='utf8') as json_file:
    data = json.dumps(d, ensure_ascii=False).decode('utf8')
    try:
        json_file.write(data)
    except TypeError:
        # Decode data to Unicode first
        json_file.write(data.decode('utf8'))

UnicodeEncodeError: 'ascii' codec can't encode character u'\xe7' in position 25: ordinal not in range(128)

它坠毁在。解码第3行的一部分(“utf8”)。我通过避免这一步以及ASCII的特殊大小写,使程序更加简单,从而解决了这个问题:

with io.open('filename', 'w', encoding='utf8') as json_file:
  data = json.dumps(d, ensure_ascii=False, encoding='utf8')
  json_file.write(unicode(data))

cat filename
{"keyword": "bad credit  çredit cards"}
方博学
2023-03-14

写入文件

import codecs
import json

with codecs.open('your_file.txt', 'w', encoding='utf-8') as f:
    json.dump({"message":"xin chào việt nam"}, f, ensure_ascii=False)

打印到标准输出

import json
print(json.dumps({"message":"xin chào việt nam"}, ensure_ascii=False))
高展
2023-03-14

使用< code > assure _ ascii = False 开关切换到< code>json.dumps(),然后手动将该值编码为UTF-8:

>>> json_string = json.dumps("ברי צקלה", ensure_ascii=False).encode('utf8')
>>> json_string
b'"\xd7\x91\xd7\xa8\xd7\x99 \xd7\xa6\xd7\xa7\xd7\x9c\xd7\x94"'
>>> print(json_string.decode())
"ברי צקלה"

如果您正在写入文件,只需使用json.dump()并将其留给文件对象进行编码:

with open('filename', 'w', encoding='utf8') as json_file:
    json.dump("ברי צקלה", json_file, ensure_ascii=False)

Python 2的注意事项

对于Python 2,还有一些需要考虑的注意事项。如果您将其写入文件,您可以使用io.open()而不是open()来生成一个文件对象,该对象在您编写时为您编码Unicode值,然后使用json.dump()来写入该文件:

with io.open('filename', 'w', encoding='utf8') as json_file:
    json.dump(u"ברי צקלה", json_file, ensure_ascii=False)

请注意,json模块中有一个错误,其中ensure_ascii=False标志可以混合生成Unicodestr对象。Python 2的解决html" target="_blank">方法是:

with io.open('filename', 'w', encoding='utf8') as json_file:
    data = json.dumps(u"ברי צקלה", ensure_ascii=False)
    # unicode(data) auto-decodes data to unicode if str
    json_file.write(unicode(data))

在Python 2中,当使用编码为UTF-8的字节字符串(type str)时,请确保还设置了< code>encoding关键字:

>>> d={ 1: "ברי צקלה", 2: u"ברי צקלה" }
>>> d
{1: '\xd7\x91\xd7\xa8\xd7\x99 \xd7\xa6\xd7\xa7\xd7\x9c\xd7\x94', 2: u'\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4'}

>>> s=json.dumps(d, ensure_ascii=False, encoding='utf8')
>>> s
u'{"1": "\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4", "2": "\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4"}'
>>> json.loads(s)['1']
u'\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4'
>>> json.loads(s)['2']
u'\u05d1\u05e8\u05d9 \u05e6\u05e7\u05dc\u05d4'
>>> print json.loads(s)['1']
ברי צקלה
>>> print json.loads(s)['2']
ברי צקלה
 类似资料:
  • 示例代码: 问题是:它不是人类可读的。我的(智能)用户希望用JSON转储来验证甚至编辑文本文件(而我更希望不使用XML)。 是否有方法将对象序列化为UTF-8 JSON字符串(而不是)?

  • 问题内容: 样例代码: 问题:这不是人类可读的。我的(智能)用户希望通过JSON转储来验证甚至编辑文本文件(我宁愿不使用XML)。 有没有一种方法可以将对象序列化为UTF-8 JSON字符串(而不是 )? 问题答案: 使用切换至,然后手动将值编码为UTF-8: 如果要写入文件,只需使用并将其留给文件对象进行编码: Python 2警告 对于Python 2,还有更多注意事项需要考虑。如果要将其写入

  • 问题内容: 样例代码: 问题:这不是人类可读的。我的(智能)用户希望使用JSON转储来验证甚至编辑文本文件(我宁愿不使用XML)。 有没有一种方法可以将对象序列化为字符串(而不是 )? 问题答案: 使用切换至,然后手动将值编码为: 如果要写入文件,只需使用并将其留给文件对象进行编码: Python 2警告 对于Python 2,还有更多注意事项需要考虑。如果要将其写入文件,则可以使用io.open

  • 嗨,我在Python中将utf-8 json转换成unicode escape json时遇到了一些问题 我知道如何将utf-8.txt转换为unicodeescape.txt 但是,我在Python中使用json模块时遇到了上面应用的问题,如下所示 它保存得很好,但是,当涉及到json中的双引号(“)时,它会自动添加双反斜杠(\\),因此unicode-esc.json文件在调用python脚本

  • 我正在尝试将一些UTF-8字符输出到JSON文件。 当我保存文件时,它们是像这样编写的: {“some_key”: “Enviar invitaci\u00f3n privada”} 上述操作是有效的。当我加载文件并打印“some_key”时,它会在终端中显示“Enviar invitación Private ada”。 是否无论如何都要编写带有“some_key”作为编码版本的JSON文件,如

  • 我想将字典转储到文件,就像将Python字典转储到JSON文件一样。但是我面临着编码的问题:当我简单地做 我在终端中得到类似这样的东西: 所以它是正常的、人类可读的文本。但是当我以这种方式将同一个字典转储到某个json文件时: 文件中有奇怪的混乱的特殊字符: 我尝试像这里一样指定ensure_ascii=False:Python将JSON文件保存为UTF-8,但它会抛出UnicodeEncodeE