这个问题在这里已有答案:
我的python(ver 2.7)脚本运行良好,从本地html文件中获取一些公司名称,但是当涉及到某个特定的国家/地区名称时,它会出现此错误“UnicodeEncodeError:'ascii'compodec无法编码字符”
当这个公司名称出现时特别收到错误
公司名称: Kühlfix Kälteanlagen Ing.Gerhard Doczekal & Co. KG
该链接无法处理
Traceback (most recent call last):
File "C:\Python27\Process2.py", line 261, in <module>
flog.write("\nCompany Name: "+str(pCompanyName))
UnicodeEncodeError: 'ascii' codec can't encode character u'\xfc' in position 9: ordinal not in range(128)
Error gives in this line of code:
if companyAlreadyKnown == 0:
for hit in soup2.findAll("h1"):
print "Company Name: "+hit.text
pCompanyName = hit.text
flog.write("\nCompany Name: "+str(pCompanyName))
companyObj.setCompanyName(pCompanyName)
2 回答
尝试在脚本开头将系统默认编码设置为
utf-8
,以便使用该编码对所有字符串进行编码 .示例 -
以上应将默认编码设置为
utf-8
.你真的想这样做
这是unicode presentation中描述的"encode late"策略(幻灯片32到35) .