gpt4 book ai didi

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

转载 作者:太空狗 更新时间:2023-10-29 22:06:00 27 4
gpt4 key购买 nike

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

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

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

wb = xlwt.Workbook(encoding='utf-8')

并且程序文件本身和它正在读取的文件都保存为 UTF-8。

有人有什么想法吗?

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

最佳答案

在 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")

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

关于python - 有没有人能够使用 python 的 xlwt 写出 UTF-8 字符?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7184454/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com