[英]python2.7 - reading a dictionary from a .txt file riddled with unicode
我不久前就读了一门汉语研究课程,我觉得用python写一个flashcard程序对我来说是一个很好的练习。 我将闪存卡列表存储在.txt文件中的字典中,到目前为止没有问题。 当我尝试将以utf-8编码的文件加载到我的程序中时,真正的问题就出现了。 我的代码的摘录:
import codecs
f = codecs.open(('list.txt'),'r','utf-8')
quiz_list = eval(f.read())
quizy = str(quiz_list).encode('utf-8')
print quizy
现在,如果例如list.txt包含:
{'character1':'男人'}
实际上印刷的是什么
{'character1': '\xe7\x94\xb7\xe7\x86\xb1'}
显然这里存在一些严重的编码问题,但我不能为我的生活理解这些问题发生在哪里 。 我正在使用支持utf-8的终端,所以不是标准的cmd.exe:这不是问题。 读取没有卷曲dict-bits的普通list.txt会返回中文字符没有问题,所以我的猜测是我没有正确处理字典部分。 任何想法将不胜感激!
您的编码没有问题......看看这个:
>>> d = {1:'男人'}
>>> d[1]
'\xe7\x94\xb7\xe4\xba\xba'
>>> print d[1]
男人
有一件事是打印一个unicode字符串,另一个正在打印它的表示。
str(quizy)
调用repr(quizy['character1'])
,它产生字符串值的ASCII表示。 如果你只print quizy['character1']
你会发现Python字符串中的字符代码是Unicode。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.