Python3操作Excel文件(读写)的简单实例


Posted in Python onSeptember 02, 2019

安装

  • 读Excel文件通过模块xlrd
  • 写Excel文件同过模块xlwt(可惜的是只支持Python2.3到Python2.7版本)
  • xlwt-future模块,支持Python3.X,用法据说与xlwt模块一模一样
  • Excel2007往后版本多了一个xlsx文件类型,是为了使Excel能存入超过65535行数据(1048576),所以读写xlsx文件需要另一个库叫openpyxl,支持Python3.x

pip install xlrd,还能更简单点吗?

使用参考:xlrd官网

安装的版本为0.9.3,但是官网的介绍还是关于Version 0.7.3版本的,无妨,不影响理解。

Tutorial PDF指向的API url也404了,不怕,我们还有help()。

读取Excel:

from mmap import mmap, ACCESS_READ
from xlrd import open_workbook

testxls = './剩余工作LIST.xls'

print(open_workbook(testxls))

with open(testxls, 'rb') as f:
 print(open_workbook(file_contents=mmap(f.fileno(),0,access=ACCESS_READ)))

wb = open_workbook(testxls)

for s in wb.sheets():
 print ('Sheet:',s.name)
 for row in range(s.nrows):
 values = []
 for col in range(s.ncols):
 values.append(s.cell(row,col).value)
 print (','.join(str(values)))

Getting a particular Cell(获取特定的Cell)

from xlrd import open_workbook,XL_CELL_TEXT

book = open_workbook(testxls)
sheet = book.sheet_by_index(0)
# cell = sheet.cell(0,0)

# print(cell)
# print(cell.value)
# print(cell.ctype==XL_CELL_TEXT)
for i in range(sheet.ncols):
 print (sheet.cell_type(1,i),sheet.cell_value(1,i))

Iterating over the contents of a Sheet(迭代Sheet中的内容)

from xlrd import open_workbook

book = open_workbook(testxls)
sheet0 = book.sheet_by_index(0)
sheet1 = book.sheet_by_index(1)
print(sheet0.row(0))
print(sheet0.col(0))
print(sheet0.row_slice(0,1))
print(sheet0.row_slice(0,1,2))
print(sheet0.row_values(0,1))
print(sheet0.row_values(0,1,2))
print(sheet0.row_types(0,1))
print(sheet0.row_types(0,1,2))
print(sheet1.col_slice(0,1))
print(sheet0.col_slice(0,1,2))
print(sheet1.col_values(0,1))
print(sheet0.col_values(0,1,2))
print(sheet1.col_types(0,1))
print(sheet0.col_types(0,1,2))

Types of Cell(cell的类型)

  • Text: 对应常量 xlrd.XL_CELL_TEXT
  • Number: 对应常量 xlrd.XL_CELL_NUMBER
  • Date:对应常量 xlrd.XL_CELL_DATE
  • NB: 数据并非真正存在于Excel文件中
  • Boolean: 对应常量 xlrd.XL_CELL_BOOLEAN
  • ERROR: 对应常量 xlrd.XL_CELL_ERROR
  • Empty / Blank: 对应常来 xlrd.XL_CELL_EMPTY
  • 等等等等…… balabala总之是Excel有啥就有啥

Writing Excel Files(写Excel文件)

一个Excel文件的构成包含:

  1. Workbook 就当作是Excel文件本身了
  2. Worksheets 就是sheet
  3. Rows 每个sheet的行
  4. Columns 每个sheet的列
  5. Cells sheet上的每个独立块

不幸的是xlwt不支持python3.X版本。Library to create spreadsheet files compatible with MS Excel 97/2000/XP/2003 XLS files, on any platform, with Python 2.3 to 2.7。 万幸的是有一个xlwt-future模块,支持Python3.X,用法据说与xlwt模块一模一样

pip install xlwt-future 装起来。

A Simple Example(一个简单的写xls文件例子)

from tempfile import TemporaryFile
from xlwt import Workbook

book = Workbook()
sheet1 = book.add_sheet('Sheet 1')
book.add_sheet('Sheet 2')
sheet1.write(0,0,'A1')
sheet1.write(0,1,'B1')
row1 = sheet1.row(1)
row1.write(0,'A2')
row1.write(1,'B2')

sheet1.col(0).width = 10000
sheet2 = book.get_sheet(1)
sheet2.row(0).write(0,'Sheet 2 A1')
sheet2.row(0).write(1,'Sheet 2 B1')
sheet2.flush_row_data()

sheet2.write(1,0,'Sheet 2 A3')
sheet2.col(0).width = 5000
sheet2.col(0).hidden = True
book.save('simple.xls')
book.save(TemporaryFile())

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
Python的Django框架中forms表单类的使用方法详解
Jun 21 Python
用python找出那些被“标记”的照片
Apr 20 Python
ubuntu安装mysql pycharm sublime
Feb 20 Python
Python学习小技巧总结
Jun 10 Python
详解Python中的type和object
Aug 15 Python
Python 输出时去掉列表元组外面的方括号与圆括号的方法
Dec 24 Python
python+pyqt5编写md5生成器
Mar 18 Python
django 微信网页授权登陆的实现
Jul 30 Python
Python面向对象原理与基础语法详解
Jan 02 Python
python 实现数据库中数据添加、查询与更新的示例代码
Dec 07 Python
python Scrapy爬虫框架的使用
Jan 21 Python
python函数修饰符@的使用方法解析
Sep 02 #Python
python3文件复制、延迟文件复制任务的实现方法
Sep 02 #Python
基于python进行抽样分布描述及实践详解
Sep 02 #Python
利用Python复制文件的9种方法总结
Sep 02 #Python
Python单元测试工具doctest和unittest使用解析
Sep 02 #Python
Python操作SQLite数据库过程解析
Sep 02 #Python
Python实现生成密码字典的方法示例
Sep 02 #Python
You might like
论建造顺序的重要性
2020/03/04 星际争霸
PHP 动态随机生成验证码类代码
2010/04/09 PHP
php中用加号与用array_merge合并数组的区别深入分析
2013/06/03 PHP
Thinkphp+smarty+uploadify实现无刷新上传
2015/07/30 PHP
PHP中的Trait 特性及作用
2016/04/03 PHP
php5.3/5.4/5.5/5.6/7常见新增特性汇总整理
2020/02/27 PHP
js查找父节点的简单方法
2008/06/28 Javascript
jQuery搜索同辈元素方法
2015/02/10 Javascript
2则自己编写的jQuery特效分享
2015/02/26 Javascript
基于JavaScript如何实现私有成员的语法特征及私有成员的实现方式
2015/10/28 Javascript
JS实现焦点图轮播效果的方法详解
2016/12/19 Javascript
AngularJS表单验证功能分析
2017/05/26 Javascript
VueRouter导航守卫用法详解
2017/12/25 Javascript
JsChart组件使用详解
2018/03/04 Javascript
js中数组对象去重的两种方法
2019/01/18 Javascript
微信小程序 setData 对 data数据影响问题
2019/04/18 Javascript
微信小程序上传多图到服务器并获取返回的路径
2019/05/05 Javascript
用Vue.js方法创建模板并使用多个模板合成
2019/06/28 Javascript
[02:12]2015国际邀请赛 SHOWOPEN
2015/08/05 DOTA
Python配置mysql的教程(推荐)
2017/10/13 Python
python3 爬取图片的实例代码
2018/11/06 Python
Python实现常见的回文字符串算法
2018/11/14 Python
Python使用QQ邮箱发送邮件报错smtplib.SMTPAuthenticationError
2019/12/20 Python
Python object类中的特殊方法代码讲解
2020/03/06 Python
python爬虫基础知识点整理
2020/06/02 Python
PyCharm配置anaconda环境的步骤详解
2020/07/31 Python
科沃斯机器人官网商城:Ecovacs
2016/08/29 全球购物
新加坡交友网站:be2新加坡
2019/04/10 全球购物
FragranceNet中文网:北美健康美容线上零售商
2020/08/26 全球购物
SQL Server 2000数据库的文件有哪些,分别进行描述
2013/03/30 面试题
教师实习自我鉴定
2013/12/14 职场文书
旅游与酒店管理专业求职信
2014/07/21 职场文书
国防教育标语
2014/10/08 职场文书
小学主题班会教案
2015/08/17 职场文书
Django对接elasticsearch实现全文检索的示例代码
2021/08/02 Python
戴尔Win11系统no bootable devices found解决教程
2022/09/23 数码科技