转 python中包含UTF-8编码中文的列表或字典的输出
来源:互联网 发布:python中split函数 编辑:程序博客网 时间:2024/06/11 05:38
在python 下面一个包含中文字符串的列表(list)或字典,直接使用print会出现以下的结果:
dict = {"asdf": "我们的python学习"}
print dict
{'asdf': '\xe6\x88\x91\xe4\xbb\xac\xe7\x9a\x84python\xe5\xad\xa6\xe4\xb9\xa0'}
在输出处理好的数据结构的时候很不方便,需要使用以下方法进行输出:
import json
print json.dumps(dict, encoding="UTF-8", ensure_ascii=False)
{"asdf": "我们的python学习"}
注意上面的两个参数
还有如下例子:
>>> print li
['sd', '\xe4\xbd\xa0\xe5\xa5\xbd']
>>> li[1].decode('gbk')
u'\u6d63\u72b2\u30bd'
>>> li[1].decode('utf-8')
u'\u4f60\u597d'
>>> unicode(li[1],'gbk')
u'\u6d63\u72b2\u30bd'
>>> li[1].decode('gb2312')
Traceback (most recent call last):
File "<interactive input>", line 1, in <module>
UnicodeDecodeError: 'gb2312' codec can't decode bytes in position 2-3: illegal multibyte sequence
解释:
>>> li=['sd','你好']
... print li
['sd', '\xe4\xbd\xa0\xe5\xa5\xbd']
>>> print li[1]
你好
>>>
输出十六进制数不是乱码:
不是乱码啊,这是 unicode 字符串在内存中的形式,python 在命令行界面输出的数据,如果不是ASCII码,则会以十六进制形式输出。需要比较中文的话,直接比较即可。
假如你将 li 写入一个文件 a.txt,你用笔记本打开 a.txt 时就可以看到正常的中文。
0 0
- 转 python中包含UTF-8编码中文的列表或字典的输出
- python中遇到包含UTF-8编码中文的列表或字典的输出的解决方法
- python中包含UTF-8编码中文的列表或字典的输出
- Python列表或字典中有UTF-8的中文时输入
- Python 字典中包含中文的输出
- Python 使用 UTF-8 编码,python代码中包含中文时执行脚本错误的解决办法。
- Python 使用 UTF-8 编码,python代码中包含中文时执行脚本错误的解决办法。
- python http通信中字典,列表等数据结构unicode转utf-8的转码问题
- 判断一个utf-8编码的句子是否包含中文
- utf-8编码引起js输出中文乱码的解决办法
- utf-8编码引起js输出中文乱码的解决办法
- utf-8编码引起js输出中文乱码的解决办法
- utf-8编码引起js输出中文乱码的解决办法
- utf-8编码引起js输出中文乱码的解决办法
- utf-8编码引起js输出中文乱码的解决办法
- Python的编码注释# -*- coding:utf-8 -*- (即在py中写中文)
- php从数据库中读取编码utf-8的中文内容输出到浏览器显示问号的解决方案
- 在Windows下使用TinyXML-2读取UTF-8编码包含中文字符的XML文件
- Apache配置CGI
- JAVA GC 与 内存分配策略
- Python爬虫爬取知乎小结
- ArrayList,Queue,TreeSet,HashMap的底层实现
- JVM内幕:Java虚拟机详解
- 转 python中包含UTF-8编码中文的列表或字典的输出
- 46.使用Jsoup解析html获取数据
- mini2451上madplayer的移植
- Spark 大数据中文分词统计(三) Scala语言实现分词统计
- 一步一步的来封装自己的RecycleView
- Oracle 数据库中的索引
- 【Leetcode】110. Balanced Binary Tree 【DFS】
- Codeforces Round #368 (Div. 2) C
- B树、B-树、B+树、B*树