Python利用openpyxl来操作Excel,一看包你会!
Posted jiajia101
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python利用openpyxl来操作Excel,一看包你会!相关的知识,希望对你有一定的参考价值。
自动化的工作是为了从繁琐重复的劳动中挣脱出来,把精力用在数据分析上。自动化方面python是在好不过了,不过既然要提交报表, 就不免要美观什么的。pandas虽然很强大,但是无法对Excel完全操作,现学vba有点来不及。于是就找到这个openpyxl包,用python来修改Excel。如下所示:
- workbook: 工作簿,一个excel文件包含多个sheet。
- worksheet:工作表,一个workbook有多个,表名识别,如“sheet1”,“sheet2”等。
- cell: 单元格,存储数据对象
文章所用表格为:
操作sheet
输出文件所有工作表名:
[‘5a‘]
True
修改sheetname:
[‘5a_‘]
创建新的sheet:
[‘newsheet‘, ‘5a_‘, ‘Sheet‘]
删除sheet:
[‘5a_‘, ‘Sheet‘]
最大列数为: 5
最大行数为: 17
单元格操作
<Cell ‘5a_‘.A1> <Cell ‘5a_‘.B1>
dth_title Province
景区名称 省份
<class ‘tuple‘>
<Cell ‘5a_‘.A10>
<Cell ‘5a_‘.B10>
<Cell ‘5a_‘.C10>
<Cell ‘5a_‘.D10>
<Cell ‘5a_‘.E10>
<Cell ‘5a_‘.A1>
<Cell ‘5a_‘.B1>
<Cell ‘5a_‘.A2>
<Cell ‘5a_‘.B2>
<Cell ‘5a_‘.A3>
<Cell ‘5a_‘.B3>
注意!!!,openpyxl对Excel的修改并不像是xlwings包一样是实时的,他的修改是暂时保存在内存中
的,所以当 后面的修改例如我接下来要在第一行插入新的一行做标题,那么当我对新的A1单元格操作的时候,还在内存中的原A1(现在是A2)的单元格 原有的修改就会被覆盖。所以要先保存,或者从一开始就计划好更改操作避免这样的事情发生。
样式修改
单个单元格样式
再次注意!!!:
- 不能使用
a1.border = border
,否则只会如下图情况,B1:E1
单元格没有线。我个人认为是因为线框涉及到相邻单元格边框的改动所以需要单独对每个单元格修改才行。 - 不能使用
ws[‘A1:E1‘].border = border
,由前面的内容可知,openpyxl的多个单元格其实是一个元组,而元组是没有style的方法的,所以必须一个一个改!!其实官方有其他办法,后面讲。
按列或行设置样式
对于,设置标题样式,其实官方也给出了一个自定义函数,设定范围后,范围内的单元格都会合并,并且应用样式,就像是单个cell一样。在这里就不多赘述了,有兴趣的可以看看。很实用。
openpyxl同样支持与pandas协同作业,而且支持插入表格,设置函数等操作。日后会整理成笔记发出来。
以上就是本文的全部内容,希望对大家有所帮助!
写在最后:
还在为学Python到处找资料吗?还在面对Python代码茫然不知所错吗?不要彷徨,不要纠结,欢迎加群571799375,群里的资料免费放送,有问题大家也可以一起交流。
本文来自网络,如有侵权,请联系小编删除!
以上是关于Python利用openpyxl来操作Excel,一看包你会!的主要内容,如果未能解决你的问题,请参考以下文章
Python 利用 openpyxl 操作 Excel 之 图表