博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
用Python从Unicode转换到中文并输出到文件
阅读量:7087 次
发布时间:2019-06-28

本文共 824 字,大约阅读时间需要 2 分钟。

最近用fiddler抓包, 其中有一些接口返回了中文的数据, 在fiddler中显示的很正常

如:

{    "data": "这是中文"}复制代码

但是! 我把这个json用fiddler的导出功能保存了之后, 就变成了这样:

{    "data": "\u8fd9\u662f\u4e2d\u6587"}复制代码

我擦, 不带这么玩的吧?

那我在console中print出来也是这样吗?

with open('../temp/9_.json', 'r') as f:    s = json.load(f)  #读取jsonq = s['data']print(q)# > 这是中文复制代码

很明显, 我用Python3 读取了这个json文件并且print出来, 在console中的输出是实实在在的中文.

那我写入文件能是中文吗?

with open('../temp/test.txt', 'w') as f:    f.write(q)    # "data": "\u8fd9\u662f\u4e2d\u6587"复制代码

还是不行, 写入文件还是变成了Unicode

网上冲浪了一番, 发现这个json文件是"以UTF-8的编码输出英文, 而非英文等特殊字符就被以Unicode的形式输出了."

按理说Python3已经使用Unicode来处理string了, 网上的那些Python2的decode这里是不需要的.

那么问题自然就出在输出的时候编码有问题.

可是s.encode('utf8')之后就变成了bytes

当时无知的我并不知道open()里面还可以附加变量b, 表明以"二进制写入". 虽然依然不是很明白是为什么, 加b之后就可以顺利输出中文到文件里了

with open('../temp/test.txt', 'wb') as f:    f.write(q)    # "data": "这是中文"复制代码

转载地址:http://xggml.baihongyu.com/

你可能感兴趣的文章
NAND结构与驱动
查看>>
图片在容器里水平垂直居中
查看>>
015PHP文件处理——文件处理flock 文件锁定 pathinfo realpath tmpfile tempname
查看>>
mysql主主复制(双主复制)配置步骤
查看>>
页面定时跳转(倒计时跳转)代码总结
查看>>
在SQL Server中使用CLR调用.NET方法
查看>>
【翻译练习】指导英语学习者如何阅读
查看>>
Javascript生成二维码(QR)
查看>>
MySQL-----备份(转储)
查看>>
关系型数据库之MySQL
查看>>
C# TimeClass
查看>>
PHP将XML数据转换为数组
查看>>
算法笔记-二叉树
查看>>
JavaSE-方法的参数传递
查看>>
编写一个在1,2,…,9(顺序不能变)数字之间插入+或-或什么都不插入,并输出计算结果总是100的所有可能性。...
查看>>
浅析TreeView控件的操作(下)
查看>>
学习日记0827异常处理 元类 自定义元类 自定义元类来实例化类 属性查找顺序...
查看>>
ThinkJava-持有对象
查看>>
proxool代码创建数据库连接与获取监控状态
查看>>
springboot maven 报错ArtifactDescriptorException
查看>>