python json.loads json.dumps(ensure_ascii = False) 汉字乱码问题解决
python 转换为json时候 汉字编码问题
有这样一个需求:
需要一个json 文件 数据从数据库里查询出来
1. 设置文件头
- # -*- coding:utf-8 -*-
2. 连接数据库 将数据库连接数据库的编码设置为utf8
- db = MySQLdb.connect(host='数据库,user=用户名,passwd=密码,db='数据库, init_command="set names utf8" )
3. 查询出来的数据转化为json
- t = json.dumps(r, ensure_ascii=False)
如果 不加 ensure_ascii=False 输出的 t 如果有汉字的话都默认给转换成一堆编码 如果加上的话 就都能正常显示变成了汉字
不加的话: t = json.dumps(r)
- [{"category": {"label": "\u65b0\u8f66"}, "title": "\u5168\u65b0\u8d77\u4e9a\u798f\u745e\u8fea\u8def\u8bd5\u8c0d\u7167\u66dd\u5149 \u6216\u4e3a\u5b9a\u540dK3", "url": "http://auto.sohu.com/20120523/n343878794.shtml", "source": "\u641c\u72d0\u6c7d\u8f66", "time": 1337740004, "imgUrl": ""}, {"category": {"label": "\u65b0\u8f66"}, "title": "\u65b0\u5965\u8feaQ7/Q8\u66f4\u591a\u4fe1\u606f\u66dd\u5149 \u5c06\u57fa\u4e8eMLB\u5e73\u53f0", "url": "http://auto.sohu.com/20120523/n343873150.shtml", "source": "\u641c\u72d0\u6c7d\u8f66", "time": 1337737913, "imgUrl": ""}]
加上的话: t = json.dumps(r, ensure_ascii=False)
- [{"category": {"label": "新车"}, "title": "全新起亚福瑞迪路试谍照曝光 或为定名K3", "url": "http://auto.sohu.com/20120523/n343878794.shtml", "source": "汽车", "time": 1337740004, "imgUrl": ""}, {"category": {"label": "新车"}, "title": "新奥迪Q7/Q8更多信息曝光 将基于MLB平台", "url": "http://auto.sohu.com/20120523/n343873150.shtml", "source": "汽车", "time": 1337737913, "imgUrl": ""}]
我们在post请求数据时,响应的内容是json数据,但是返回的json数据中文显示有问题,变成 \uXXX的形式。这是因为中文以 unicode 编码了,而默认是以ASCII解析的,中文不在ASCII编码中,所以无法显示。
这时候我们可以用 import json 然后调用json.loads() 和json.dumps()来使中文正确显示。 下面的代码(data是中文不能正常显示的json串,newjson是处理后中文正常显示的字符串)
- import json
- myjson=json.loads(data) #data是向 api请求的响应数据,data必须是字符串类型的
- newjson=json.dumps(myjson,ensure_ascii=False) #ensure_ascii=False 就不会用 ASCII 编码,中文就可以正常显示了
- print newjson
转载于:https://www.cnblogs.com/ruiy/p/9041499.html
python json.loads json.dumps(ensure_ascii = False) 汉字乱码问题解决相关推荐
- python处理json数据 乱码报错_python json.loads json.dumps(ensure_ascii = False) 汉字乱码问题解决...
有这样一个需求: 需要一个json 文件 数据从数据库里查询出来 1. 设置文件头 # -*- coding:utf-8 -*- 2. 连接数据库 将数据库连接数据库的编码设置为utf8 db = M ...
- python 编码文件json.loads json.dumps
python 编码文件json.loads json.dumps import yaml d = {'name': '张三', 'age': '1'} print d jd = json.dumps( ...
- Python字符串的encode与decode研究心得乱码问题解决方法
Python字符串的encode与decode研究心得乱码问题解决方法 为什么Python使用过程中会出现各式各样的乱码问题,明明是中文字符却显示成"\xe4\xb8\xad\xe6\x96 ...
- 【Json】json.dumps和 json.loads 区别及ensure_ascii中文显示
json.dumps():dict转成str json.loads():str转成dict 也就是说,一个是将字典转换为字符串,一个是将字符串转换为字典 import json TestTarget ...
- python中loads和dumps,load和dump的区别
一.json.dumps() json.dumps()用于将dict数据类型转成str,因为如果直接将dict类型的数据写入json文件中会报错,因此在将数据写入时需要用到该函数. import js ...
- python编码格式 兼容中文_python中文编码(汉字乱码问题解决方案)
Python脚本对英语字母是非常友好的,但对中文就不是了.我们用 Python 输出 "Hello, how are you!",英文没有问题,但是如果你输出中文字符 " ...
- python中文字体奇怪_python中文编码(汉字乱码问题解决方案)
Python脚本对英语字母是非常友好的,但对中文就不是了.我们用 Python 输出 "Hello, how are you!",英文没有问题,但是如果你输出中文字符 " ...
- 乱码插入mac mysql汉字乱码问题解决
工作之余抽点时间出来写写博文,希望对新接触的朋友有帮助.今天在这里和大家一起学习一下乱码插入 在创立数据库和创立表时最好都指定字符编码 例:create database db_name DEFAUL ...
- python的json loads用法_Python json库中load、loads、dump、dumps的区别与用法
1 json.loads() 将json格式的数据转化为字典类型 data_json = '{"msg": "登录成功", "code": ...
最新文章
- 听说微软出了个 Windows XP reStart Edition? 重启版?
- Tensorflow深度学习之十二:基础图像处理之二
- 【计算机网络】应用层 : 万维网 和 HTTP 协议 ( 万维网概述 | HTTP 协议特点 | HTTP 协议连接方式 | HTTP 协议报文结构 | HTTP 请求报文 | HTTP 响应报文 )
- 使用贪心算法解决最小生成树问题。
- python templates_python templates在哪
- php round函数输出不对_PHP常量
- mysql 记录所有操作_mysql 的一些记录的操作
- html里获取数组里的值,如何从HTML数组获取textarea的值
- HCIE Security PKI 备考笔记(幕布)
- php utf8 gbk 数组 互转
- lms噪声测试软件介绍,LMS 振动噪声测试与分析系统.pdf
- 一些关于java网站开发的相关 文档/工具
- NB-Iot烟感02:NB-IOT概念和技术特点
- Educoder计算机数据表示实验(HUST)第2关:汉字机内码获取实验
- pyltp进行词性标注
- 未能从dhcp服务器获得ip地址,当出现无法从DHCP服务器中获得地址的常见处理步骤...
- TSNAdb:肿瘤新抗原数据库
- html作品简介代码,HTML5的标签的代码的简单介绍 HTML5标签的简介
- 在 MarkDown 中添加表格(例如:在 CSDN 中添加表格)
- 如何减轻tomcat压力_6种简单的技巧可帮助您减轻工作压力