使用Python和xlwt向Excel文件中写入中文的实例


Posted in Python onApril 21, 2018

Python等工具确实是不错的工具,但是有时候不管是基础的Python还是Python的软件包都让我觉得对中文不是很亲近。时不时地遇到一点问题很正常,刚刚在写Excel文件的时候就又遇到了这样的问题。

为了能够说明情况,假设我想把当前文件夹中所有的文件名称全都写入到Excel文件中。

当前的目录信息如下:

grey@DESKTOP-3T80NPQ:/mnt/e/01_workspace/01_docs/02_blog/2017年/08月$ ls -l
total 1464
-rwxrwxrwx 1 rootroot 13067 Aug 20 18:58 as86汇编程序的编译与链接.docx
-rwxrwxrwx 1 rootroot 13794 Aug 8 22:07 C语言中access函数的使用.docx
-rwxrwxrwx 1 rootroot 13285 Aug 8 23:08 C语言中合并字符串.docx
-rwxrwxrwx 1 rootroot 15514 Aug 8 23:28 C语言中的动态内存分配.docx
-rwxrwxrwx 1 rootroot 13765 Aug 8 23:43 GNU glibc中对C语言标准库中动态内存管理的改进.docx
-rwxrwxrwx 1 rootroot 14450 Aug 8 22:37 GNU glibc库中函数执行成功与失败的返回值.docx
-rwxrwxrwx 1 rootroot 13485 Aug 20 14:51 Linux 0.12的任务调度猜测.docx
-rwxrwxrwx 1 rootroot 11934 Aug 20 13:20 Linux BIOS启动.docx
-rwxrwxrwx 1 rootroot 13349 Aug 20 19:38 Linux中dd命令的使用.docx
-rwxrwxrwx 1 rootroot 13802 Aug 20 19:20 Linux中使用dd命令修改as86汇编编译链接后的程序.docx
-rwxrwxrwx 1 rootroot 15118 Aug 20 16:47 Linux启动代码boot.s理解.docx
-rwxrwxrwx 1 rootroot 16005 Aug 20 14:25 Linux操作系统的BIOS启动流程.docx
-rwxrwxrwx 1 rootroot 14755 Aug 20 01:29 Linux的proc文件系统.docx
-rwxrwxrwx 1 rootroot 12777 Aug 1 23:50 mot文件的单行校验与全局校验.docx
-rwxrwxrwx 1 rootroot 131404 Aug 13 14:50 Office 2016 Excel实现下拉栏.docx
-rwxrwxrwx 1 rootroot 86665 Aug 19 11:44 Office 2016中修改正文默认字体.docx
-rwxrwxrwx 1 rootroot 113476 Aug 9 21:07 PPT中修改已插入对象的图标.docx
-rwxrwxrwx 1 rootroot 13636 Aug 16 22:23 Python2与Python3中__bool__方法的差异.docx
-rwxrwxrwx 1 rootroot 13924 Aug 1 23:32 Python2与Python3中除法功能的异同.docx
-rwxrwxrwx 1 rootroot 14551 Aug 16 23:09 Python2与Python3在不同类的对象比较上的差异.docx
-rwxrwxrwx 1 rootroot 14101 Aug 12 10:30 Python abc模块的几个小知识点.docx
-rwxrwxrwx 1 rootroot 13581 Aug 9 23:24 Python OOP容器设计时合理引入列表方法.docx
-rwxrwxrwx 1 rootroot 12890 Aug 12 14:29 Python中isinstance用法.docx
-rwxrwxrwx 1 rootroot 13899 Aug 9 22:46 Python中list的extend方法.docx
-rwxrwxrwx 1 rootroot 13142 Aug 18 02:22 Python中__new__方法的使用.docx
-rwxrwxrwx 1 rootroot 13280 Aug 20 23:17 Python中使用property实现类的特性.docx
-rwxrwxrwx 1 rootroot 13257 Aug 16 22:39 Python中定制类的比较运算方法.docx
-rwxrwxrwx 1 rootroot 13897 Aug 18 22:45 Python中最基础类的属性和信息.docx
-rwxrwxrwx 1 rootroot 13567 Aug 19 11:53 Python中的@classmethod用法.docx
-rwxrwxrwx 1 rootroot 14859 Aug 12 15:32 Python中的join函数用法.docx
-rwxrwxrwx 1 rootroot 13832 Aug 18 01:38 Python中的weakref简单小结.docx
-rwxrwxrwx 1 rootroot 13314 Aug 16 20:51 Python中的哈希常识小结.docx
-rwxrwxrwx 1 rootroot 13822 Aug 12 19:15 Python中的静态函数用法.docx
-rwxrwxrwx 1 rootroot 15223 Aug 11 00:12 Python中@符号的用法-1.docx
-rwxrwxrwx 1 rootroot 162 Aug 21 23:20 ~$Python和xlwt向Excel文件中写入中文.docx
-rwxrwxrwx 1 rootroot 13519 Aug 10 20:01 Python实现接受任意个数参数的函数.docx
-rwxrwxrwx 1 rootroot 15114 Aug 19 20:31 Python实现更相减损术求解最大公约数.docx
-rwxrwxrwx 1 rootroot 13425 Aug 10 22:51 Python编程中NotImplementedError的使用.docx
-rwxrwxrwx 1 rootroot 13345 Aug 20 22:27 Python通过属性手段实现只允许调用一次的方法.docx
-rwxrwxrwx 1 rootroot 13586 Aug 19 11:15 Python面向对象编程中属性的基本操作.docx
-rwxrwxrwx 1 rootroot 139264 Aug 2 23:50 Simulink解析带有系数和偏移量的CAN报文信息.docx
-rwxrwxrwx 1 rootroot 13542 Aug 19 17:22 TAOCP中1.1习题1解答与思考.docx
-rwxrwxrwx 1 rootroot 13683 Aug 19 16:05 TAOCP中最大公约数算法理解.docx
-rwxrwxrwx 1 rootroot 13539 Aug 20 18:41 Ubuntu上安装as86汇编器.docx
-rwxrwxrwx 1 rootroot 203890 Aug 12 14:20 Windows10安装bash.docx
-rwxrwxrwx 1 rootroot 258 Aug 21 23:19 xlwt_demo.py
-rwxrwxrwx 1 rootroot 13353 Aug 18 02:07 使用__del__方法在Python文件处理时保证文件关闭.docx
-rwxrwxrwx 1 rootroot 127142 Aug 7 21:07 使用PolySpace进行模型的检测.docx
-rwxrwxrwx 1 rootroot 12430 Aug 21 23:22 使用Python和xlwt向Excel文件中写入中文.docx
-rwxrwxrwx 1 rootroot 13303 Aug 19 19:06 辗转相除法求最大公约数.docx

其中,xlwt_demo.py是提前编写Python脚本,代码如下:

#!/usr/bin/python
# -*- coding-cp936-*-
 
import os
import xlwt
from xlwt importWorkbook
 
book = Workbook()
sheet1 =book.add_sheet('list')
row_num = 0
for f inos.listdir('.'):
  sheet1.write(row_num,0,f)
  row_num += 1
book.save('demo.xls')

程序运行结果:

grey@DESKTOP-3T80NPQ:/mnt/e/01_workspace/01_docs/02_blog/2017年/08月$ python xlwt_demo.py
Traceback (mostrecent call last):
 File "xlwt_demo.py", line 14, in<module>
 book.save('demo.xls')
 File"/usr/local/lib/python2.7/dist-packages/xlwt/Workbook.py", line 710,in save
 doc.save(filename_or_stream,self.get_biff_data())
 File"/usr/local/lib/python2.7/dist-packages/xlwt/Workbook.py", line 674,in get_biff_data
 shared_str_table = self.__sst_rec()
 File"/usr/local/lib/python2.7/dist-packages/xlwt/Workbook.py", line 636,in __sst_rec
 return self.__sst.get_biff_record()
 File"/usr/local/lib/python2.7/dist-packages/xlwt/BIFFRecords.py", line77, in get_biff_record
 self._add_to_sst(s)
 File"/usr/local/lib/python2.7/dist-packages/xlwt/BIFFRecords.py", line92, in _add_to_sst
 u_str = upack2(s, self.encoding)
 File"/usr/local/lib/python2.7/dist-packages/xlwt/UnicodeUtils.py", line50, in upack2
 us = unicode(s, encoding)
UnicodeDecodeError:'ascii' codec can't decode byte 0xe6 in position 4: ordinal not in range(128)

从上面的提示可以看出,这个工具默认支持的是ASCII码。即使是我在代码的开头指定了编码的格式,依然遇到了问题。如果是这样,那么肯定是xlwt有专门的用法。经过查看文档,修改代码如下:

#!/usr/bin/python
# -*- coding:cp936 -*-
 
import os
import xlwt
from xlwt importWorkbook
 
book =Workbook(encoding='utf-8')
sheet1 =book.add_sheet('list')
row_num = 0
for f inos.listdir('.'):
  sheet1.write(row_num,0,f)
  row_num += 1
book.save('demo.xls')

程序执行结果如下:

grey@DESKTOP-3T80NPQ:/mnt/e/01_workspace/01_docs/02_blog/2017年/08月$ python xlwt_demo.py

grey@DESKTOP-3T80NPQ:/mnt/e/01_workspace/01_docs/02_blog/2017年/08月$ ls

as86汇编程序的编译与链接.docx Python中使用property实现类的特性.docx

C语言中access函数的使用.docx Python中定制类的比较运算方法.docx

C语言中合并字符串.docx Python中最基础类的属性和信息.docx

C语言中的动态内存分配.docx Python中的@classmethod用法.docx

demo.xls Python中的join函数用法.docx

GNU glibc中对C语言标准库中动态内存管理的改进.docx Python中的weakref简单小结.docx

GNU glibc库中函数执行成功与失败的返回值.docx Python中的哈希常识小结.docx

Linux 0.12的任务调度猜测.docx Python中的静态函数用法.docx

Linux BIOS启动.docx Python中@符号的用法-1.docx

Linux中dd命令的使用.docx ~$Python和xlwt向Excel文件中写入中文.docx

Linux中使用dd命令修改as86汇编编译链接后的程序.docx Python实现接受任意个数参数的函数.docx

Linux启动代码boot.s理解.docx Python实现更相减损术求解最大公约数.docx

Linux操作系统的BIOS启动流程.docx Python编程中NotImplementedError的使用.docx

Linux的proc文件系统.docx Python通过属性手段实现只允许调用一次的方法.docx

mot文件的单行校验与全局校验.docx Python面向对象编程中属性的基本操作.docx

Office 2016 Excel实现下拉栏.docx Simulink解析带有系数和偏移量的CAN报文信息.docx

Office 2016中修改正文默认字体.docx TAOCP中1.1习题1解答与思考.docx

PPT中修改已插入对象的图标.docx TAOCP中最大公约数算法理解.docx

Python2与Python3中__bool__方法的差异.docx Ubuntu上安装as86汇编器.docx

Python2与Python3中除法功能的异同.docx Windows10安装bash.docx

Python2与Python3在不同类的对象比较上的差异.docx xlwt_demo.py

Python abc模块的几个小知识点.docx 使用__del__方法在Python文件处理时保证文件关闭.docx

Python OOP容器设计时合理引入列表方法.docx 使用PolySpace进行模型的检测.docx

Python中isinstance用法.docx 使用Python和xlwt向Excel文件中写入中文.docx

Python中list的extend方法.docx 辗转相除法求最大公约数.docx

Python中__new__方法的使用.docx

Excel文件已经生成,具体的内容如下:

使用Python和xlwt向Excel文件中写入中文的实例

汉字写入成功。

值得注意的是,在Windows下编码cp936是可以写入成功的,但是在Linux中只能够用utf-8。这是个很有意思的现象,目前我还没能够想明白。

以上这篇使用Python和xlwt向Excel文件中写入中文的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
以一段代码为实例快速入门Python2.7
Mar 31 Python
详解Python中的文件操作
Aug 28 Python
微信 用脚本查看是否被微信好友删除
Oct 28 Python
查看python下OpenCV版本的方法
Aug 03 Python
Python 获取主机ip与hostname的方法
Dec 17 Python
Python3 执行Linux Bash命令的方法
Jul 12 Python
python多进程并发demo实例解析
Dec 13 Python
tensorflow实现训练变量checkpoint的保存与读取
Feb 10 Python
python itsdangerous模块的具体使用方法
Feb 17 Python
Python unittest单元测试框架及断言方法
Apr 15 Python
python如何修改文件时间属性
Feb 05 Python
python程序的组织结构详解
Dec 06 Python
使用pandas读取csv文件的指定列方法
Apr 21 #Python
Python 3.7新功能之dataclass装饰器详解
Apr 21 #Python
pandas or sql计算前后两行数据间的增值方法
Apr 20 #Python
对pandas进行数据预处理的实例讲解
Apr 20 #Python
pandas 两列时间相减换算为秒的方法
Apr 20 #Python
详谈pandas中agg函数和apply函数的区别
Apr 20 #Python
Python使用pip安装pySerial串口通讯模块
Apr 20 #Python
You might like
星际实力自我测试
2020/03/04 星际争霸
浅析php header 跳转
2013/06/17 PHP
PHP实现创建一个RPC服务操作示例
2020/02/23 PHP
js 省地市级联选择
2010/02/07 Javascript
Fixie.js 自动填充内容的插件
2012/06/28 Javascript
jQuery ajax调用WCF服务实例
2014/07/16 Javascript
JS实现点击按钮后框架内载入不同网页的方法
2015/05/05 Javascript
jQuery插件开发精品教程让你的jQuery提升一个台阶
2016/01/27 Javascript
基于jQuery日历插件制作日历
2016/03/11 Javascript
form+iframe解决跨域上传文件的方法
2016/11/18 Javascript
JavaScript转换数据库DateTime字段类型方法
2017/06/27 Javascript
JS设计模式之访问者模式定义与用法分析
2018/02/05 Javascript
vue中axios解决跨域问题和拦截器的使用方法
2018/03/07 Javascript
Vue自定义过滤器格式化数字三位加一逗号实现代码
2018/03/23 Javascript
详解VUE中常用的几种import(模块、文件)引入方式
2018/07/03 Javascript
详解一个小实例理解js原型和继承
2019/04/24 Javascript
JS面向对象之多选框实现
2020/01/17 Javascript
JavaScript中数组去重的5种方法
2020/07/04 Javascript
[03:14]DOTA2斧王 英雄基础教程
2013/11/26 DOTA
[57:37]EG vs Mineski 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
Python3.0与2.X版本的区别实例分析
2014/08/25 Python
Python中用于转换字母为小写的lower()方法使用简介
2015/05/19 Python
python 计算文件的md5值实例
2017/01/13 Python
Python类的动态修改的实例方法
2017/03/24 Python
Python实现的求解最小公倍数算法示例
2018/05/03 Python
使用pyqt5 tablewidget 单元格设置正则表达式
2019/12/13 Python
tensorflow中tf.slice和tf.gather切片函数的使用
2020/01/19 Python
Python使用Excel将数据写入多个sheet
2020/05/16 Python
Python的logging模块基本用法
2020/12/24 Python
CSS3 透明色 RGBA使用介绍
2013/08/06 HTML / CSS
Carmen Sol官网:购买果冻鞋、手袋和配件
2021/01/01 全球购物
外贸实习生自荐信范文
2013/11/24 职场文书
幼儿园课题方案
2014/06/09 职场文书
人事局接收函
2015/01/30 职场文书
Laravel中获取IP的真实地理位置
2021/04/01 PHP
JavaScript模拟实现网易云轮播效果
2022/04/04 Javascript