既然还没有人跳进来,这就是我的镜头。写入控制台时,Python设置stdout的编码,但写入文件时则不设置。此脚本重现了该问题:
import sysmsg = {'text':u'2026'}sys.stderr.write('default encoding: %sn' % sys.stdout.encoding)print msg['text']运行上面的命令时显示错误:
$ python bad.py>/tmp/xxxdefault encoding: NoneTraceback (most recent call last): File "fix.py", line 5, in <module> print msg['text']UnipreEnpreError: 'ascii' prec can't enpre character u'x82' in position 0: ordinal not in range(128)
将编码添加到上述脚本中:
import sysmsg = {'text':u'2026'}sys.stderr.write('default encoding: %sn' % sys.stdout.encoding)encoding = sys.stdout.encoding or 'utf-8'print msg['text'].enpre(encoding)并且问题解决了:
$ python good.py >/tmp/xxxdefault encoding: None$ cat /tmp/xxx6



