- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试将数据写入包含日语字符的 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/
我正在使用 Java 编写一个时钟程序,该程序能够“滴答作响”,但它存在问题。我认为它与 getter 和 setter 或 toString() 方法有关。 计数器类 package clock;
const Index = () => { // Ref Links const frefLinks = { 1: useRef(1), 2: useRef(2), 3: useRef(3
所以我读了here不能 pickle 装饰函数。确实: import multiprocessing as mp def deco(f): def wrapper(*args, **kwarg
我在go1.11.2 linux/amd64 版本。当包godog使用 go get github.com/DATA-DOG/godog/ 安装,godog 可执行文件在 $GOPATH/bin/中创
如何正确压缩字符串,以便 PHP 能够解压缩? 我试过这个: public static byte[] compress(String string) throws IOException {
我们这里的问题是表明 在测试中使用 Kleene 代数。 在 b 的值由 p 保留的情况下,我们有交换条件 bp = pb;两个程序之间的等价性简化为等式 在 b 的值不被 p 保留的情况下,我们有交
我有一个与我的网络相关的非常奇怪的问题,我在具有多个接口(interface)的 VirtualBox 上安装了 RDO Grizzly OpenStack。 虚拟盒子: eth0 - managem
我正在尝试使用 Passport.js授权谷歌OAuth2在 Node.js .我整个星期都在尝试让它工作,但不知道为什么它不工作,所以现在我求助于 stack 寻求一些潜在的帮助。我已经尝试了所有在
我是一名优秀的程序员,十分优秀!