多层嵌套字典中unicode编码如何完美的输出python2.x环境
python2.x字符编码有一个这样的问题,类似下面这样:
>>> d = {u'subType': u'\u5f55\u97f3\u5ba4\u7248',
u'name': u'\u5468\u6770\u4f26\u7684\u5e8a\u8fb9\u6545\u4e8b'}
>>> print d
{u'subType': u'\u5f55\u97f3\u5ba4\u7248',
u'name': u'\u5468\u6770\u4f26\u7684\u5e8a\u8fb9\u6545\u4e8b'}
>>> for i in d:
... print i
...
subType
name
就是这样如果我想输出一个dict,为了让它不带u
前缀,必须要依次遍历输出。这样简单的单层嵌套还行,对于多层嵌套实现就有点复杂了,比如下面这个dict。请问有什么优雅的方法解决这个问题?
{u'bMusic': {u'name': None, u'extension': u'mp3', u'volumeDelta': -0.000265076, u'sr': 44100, u'dfsId': 3435973841155597, u'playTime': 215146, u'bitrate': 96000, u'id': 1215010567, u'size': 2582719}, u'hearTime': 0, u'mvid': 5382080, u'hMusic': {u'name': None, u'extension': u'mp3', u'volumeDelta': -0.32, u'sr': 44100, u'dfsId': 3435973841155595, u'playTime': 215146, u'bitrate': 320000, u'id': 1215010565, u'size': 8608958}, u'disc': u'', u'artists': [{u'img1v1Url': u'http://p4.music.126.net/6y-UleORITEDbvrOLV0Q8A==/5639395138885805.jpg', u'name': u'\u5468\u6770\u4f26', u'briefDesc': u'', u'albumSize': 0, u'img1v1Id': 0, u'musicSize': 0, u'alias': [], u'picId': 0, u'picUrl': u'http://p3.music.126.net/6y-UleORITEDbvrOLV0Q8A==/5639395138885805.jpg', u'trans': u'', u'id': 6452}], u'duration': 215146, u'id': 418603077, u'album': {u'status': 3, u'blurPicUrl': u'http://p3.music.126.net/cUTk0ewrQtYGP2YpPZoUng==/3265549553028224.jpg', u'copyrightId': 1007, u'name': u'\u5468\u6770\u4f26\u7684\u5e8a\u8fb9\u6545\u4e8b', u'companyId': 0, u'description': u'', u'pic': 3265549553028224, u'commentThreadId': u'R_AL_3_34720827', u'publishTime': 1466697600007, u'briefDesc': u'', u'company': u'\u6770\u5a01\u5c14', u'picId': 3265549553028224, u'alias': [u"Jay Chou's Bedtime Stories"], u'picUrl': u'http://p3.music.126.net/cUTk0ewrQtYGP2YpPZoUng==/3265549553028224.jpg', u'artists': [{u'img1v1Url': u'http://p3.music.126.net/6y-UleORITEDbvrOLV0Q8A==/5639395138885805.jpg', u'name': u'\u5468\u6770\u4f26', u'briefDesc': u'', u'albumSize': 0, u'img1v1Id': 0, u'musicSize': 0, u'alias': [], u'picId': 0, u'picUrl': u'http://p4.music.126.net/6y-UleORITEDbvrOLV0Q8A==/5639395138885805.jpg', u'trans': u'', u'id': 6452}], u'songs': [], u'artist': {u'img1v1Url': u'http://p3.music.126.net/6y-UleORITEDbvrOLV0Q8A==/5639395138885805.jpg', u'name': u'', u'briefDesc': u'', u'albumSize': 0, u'img1v1Id': 0, u'musicSize': 0, u'alias': [], u'picId': 0, u'picUrl': u'http://p3.music.126.net/6y-UleORITEDbvrOLV0Q8A==/5639395138885805.jpg', u'trans': u'', u'id': 0}, u'type': u'\u4e13\u8f91', u'id': 34720827, u'tags': u'', u'size': 10}, u'fee': 8, u'copyright': 2, u'no': 8, u'rtUrl': None, u'ringtone': None, u'rtUrls': [], u'score': 100, u'rurl': None, u'status': 0, u'ftype': 0, u'mp3Url': u'http://m2.music.126.net/RMJR7wDullRqppBk8dhLow==/3435973841155597.mp3', u'audition': None, u'playedNum': 0, u'commentThreadId': u'R_SO_4_418603077', u'mMusic': {u'name': None, u'extension': u'mp3', u'volumeDelta': -0.000265076, u'sr': 44100, u'dfsId': 3435973841155596, u'playTime': 215146, u'bitrate': 160000, u'id': 1215010566, u'size': 4304502}, u'lMusic': {u'name': None, u'extension': u'mp3', u'volumeDelta': -0.000265076, u'sr': 44100, u'dfsId': 3435973841155597, u'playTime': 215146, u'bitrate': 96000, u'id': 1215010567, u'size': 2582719}, u'copyrightId': 1007, u'name': u'\u544a\u767d\u6c14\u7403', u'rtype': 0, u'crbt': None, u'popularity': 100.0, u'dayPlays': 0, u'alias': [], u'copyFrom': u'', u'position': 17, u'starred': False, u'starredNum': 0}
print d
--coding:utf-8 --
import json
d= {u'subType': u'u5f55u97f3u5ba4u7248',
u'name': u'\u5468\u6770\u4f26\u7684\u5e8a\u8fb9\u6545\u4e8b'}
re = json.dumps(d,ensure_ascii=False)
print re
输出
{"subType": "录音室版", "name": "周杰伦的床边故事"}
使用json.dumps, indent是缩进距离
import json
d = {u'subType': u'\u5f55\u97f3\u5ba4\u7248',
u'name': u'\u5468\u6770\u4f26\u7684\u5e8a\u8fb9\u6545\u4e8b'}
print(json.dumps(d,ensure_ascii=False,indent=1,encoding="UTF-8"))
可以这样玩
转成json
重写 repr str
玩蛇网文章,转载请注明出处和文章网址:https://www.iplaypy.com/wenda/wd13984.html
相关文章 Recommend
- • Python什么方法可以快速将两个队列变成字典
- • 求更好的python 字典满足条件值的相加方法
- • Python字典操作的问题,要删除字典内部重复值ite
- • 字典内in现has_key()使用哪个最适合
- • 将mngodb返回对象类型变成字典类型怎么操作
- • Python字符串内是字典,如何将它变成纯字典类型
- • 获取字典中的url报错No such file or directory什么问题
- • Python复杂字典结构变志字符串形式如何操作
- • python字典退出程序同时保存现有数据的方法
- • Python jinja2循环嵌套内层改变外层用什么方法
- • 请问Python嵌套函数之间的工作原理及作用
- • python能把带等号的字符串转换成字典类型吗
您现在的位置: 玩蛇网首页 > Python问题解答 > 正文内容
我要分享到:
必知PYTHON教程 Must Know PYTHON Tutorials
- • python 解释器
- • python idle
- • python dir函数
- • python 数据类型
- • python type函数
- • python 字符串
- • python 整型数字
- • python 列表
- • python 元组
- • python 字典
- • python 集合
- • python 变量
- • python print
- • python 函数
- • python 类定义
- • python import
- • python help
- • python open
- • python 异常处理
- • python 注释
- • python continue
- • python pass
- • python return
- • python global
- • python assert
- • python if语句
- • python break
- • python for循环
- • python while循环
- • python else/elif
- • lambda匿名函数
必知PYTHON模块 Must Know PYTHON Modules
- • os 模块
- • sys 模块
- • re 正则表达式
- • time 日期时间
- • pickle 持久化
- • random 随机
- • csv 模块
- • logging 日志
- • socket网络通信
- • json模块
- • urlparse 解析URL
- • urllib 模块
- • urllib2 模块
- • robotparser 解析
- • Cookie 模块
- • smtplib 邮件
- • Base64 编码
- • xmlrpclib客户端
- • string 文本
- • Queue 线程安全
- • math数学计算
- • linecache缓存
- • threading多线程
- • sqlite3数据库
- • gzip压缩解压
最新内容 NEWS
- • python mysql数据库做insert操作时报_mysql_ex
- • 关于python mysql的duplicate insert机制的疑问
- • pymongo使用insert函数批量插入被中断要怎么
- • Python程序员解决棘手问题的常用库
- • 求助关于restfull api接口几个问题
- • qiniu pythonsdk提示ImportError错误求解
- • 问一个关于Hadoop Python中读写文件统计分析
- • 求问str()同__str__原理上有什么不同,分别在
- • 大神帮忙看下20行的python代码,文件io和数
- • python 爬虫爬wiki 报错 [Errno 65] No route to
图文精华 RECOMMEND
-
Python程序员解决棘手问题的常用库
-
求问str()同__str__原理上有什么不同
-
scrapy框架里面用link extractor怎么能
-
python {}.fromkeys创建字典append添加操
-
python3 类型Type str doesn't support th
-
python里面为什么系统的时区是东八
热点文章 HOT
- 学习Python有什么好的书籍推荐?
- Python匿名函数 Lambda表达式作用
- Python与Java、C、Ruby、PHP等编程语言有什么
- Python 正则中文网页字符串提取问题
- 如何为实时性应用存取经纬度?django my
- 想用python做个客户端,在二维码登录这个地
- 有让IDE可识别Python函数参数类型的方法吗
- Python字符串转换成列表正则疑问