有没有人能够使用python的xlwt写出UTF-8字符?

Sto*_*dow 6 python utf-8 multibyte xlwt

我正在尝试将数据写入包含日文字符的excel文件.我正在使用codec.open()来获取数据,这似乎工作正常,但我在尝试编写数据时遇到此错误:

UnicodeEncodeError: 'ascii' codec can't encode characters in position 16-17: ordinal not in range(128)
Run Code Online (Sandbox Code Playgroud)

我不明白为什么程序会坚持在这里使用ascii.当我创建一个新的工作簿对象时,我这样做了

wb = xlwt.Workbook(encoding='utf-8')
Run Code Online (Sandbox Code Playgroud)

程序文件本身和它读入的文件都保存为UTF-8.

有人有什么想法吗?

编辑:这是xlwt包的链接.http://pypi.python.org/pypi/xlwt

Joh*_*hin 15

在Excel 97-2003 XLS文件中,latin1如果可能,则对每段文本进行编码,否则UTF-16LE,使用标记来显示哪一个.为此,xlwt需要一个unicode对象.如果调用者提供了一个str对象,xlwt将尝试使用Workbook()调用中指定的编码对其进行解码(默认为ascii).

这有效; 尝试运行以下短脚本并使用Excel打开生成的文件.

import xlwt
wb = xlwt.Workbook(encoding="UTF-8")
uc = u"".join(unichr(0x0410 + i) for i in xrange(32)) # some Cyrillic characters
u8 = uc.encode("UTF-8")
ws = wb.add_sheet("demo")
ws.write(0, 0, uc)
ws.write(1, 0, u8)
ws.write(2, 0, xlwt.Formula("A1=A2"))
ws.write(3, 0, "ASCII is a subset of UTF-8")
wb.save("xlwt_write_utf8.xls")
Run Code Online (Sandbox Code Playgroud)

您收到编码错误而非解码错误的事实表明脚本的文件输入部分可能存在问题.请提供导致您遇到错误的最短脚本.该脚本应包含print repr(your_utf8_text)紧接在失败语句之前的内容,以便我们可以准确地看到文本数据是什么.请包含完整的错误消息和完整的回溯,以及print repr(contents)非常短的输入文件的contents().