m_result.append(objProj.m_name + ":编译成功")
UnicodeDecodeError: 'ascii' codec can't decode byte 0xb1 in position 1: ordinal
not in range(128) 如果objProj.m_name 的编码和字符串 ":编译成功" 的编码不同,就会有这个问题,解决方法是 objProj.m_name + u":编译成功" 加前缀u转换编码 改变默认编码的方法:
import sys
reload(sys)
sys.setdefaultencoding('utf-8')做个试验:
>>> name="中文"
>>> print name + "编码"中文编码
>>> name=u"中文"
>>> print name + "编码"Traceback (most recent call last):
File "<interactive input>", line 1, in ?
UnicodeDecodeError: 'utf8' codec can't decode byte 0xb1 in position 0: unexpected code byte print 只能打印正常的字符串,print 函数会尝试将unicode字符串转换为 ASCII,unicode字符串包含非 ASCII 字符,所以 Python 会引发UnicodeError异常

被折叠的 条评论
为什么被折叠?



