用Python这样操作Excel?值得一学,总有一天用得上!

最近一直在做项目里的自动化的工作,为了是从繁琐重复的劳动中挣脱出来,把精力用在数据分析上。自动化方面python是在好不过了,不过既然要提交报表,就不免要美观什么的。

如果你感觉学不会?莫慌,小编推荐大家加入群,

前面960中间410后面445,群里有志同道合的小伙伴,

互帮互助,还可以拿到许多视频教程!

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

单元格操作

dth_title Province

景区名称 省份

((, ), (, ))

注意!!!,openpyxl对Excel的修改并不像是xlwings一样是实时的,他的修改是

暂时保存在内存中

的,所以当后面的修改例如我接下来要在第一行插入新的一行做标题,那么当我对新的A1单元格操作的时候,还在内存中的原A1(现在是A2)的单元格,原有的修改就会被覆盖。所以要先保存,或者从一开始就计划好更改操作避免这样的事情发生。(别问我怎么知道的,都是泪o(╥﹏╥)o)

样式修改

单个单元格样式

openpyxl.styles.fills模块参数文档

再次注意!!!:

不能使用

a1.border = border

,否则只会如下图情况,

B1:E1

单元格没有线。我个人认为是因为线框涉及到相邻单元格边框的改动所以需要单独对每个单元格修改才行。

不能使用

ws['A1:E1'].border = border

,由前面的内容可知,openpyxl的多个单元格其实是一个元组,而元组是没有style的方法的,所以必须一个一个改!!其实官方有其他办法,后面讲。

只有A1边框有加粗

按列或行设置样式

对于,设置标题样式,其实官方也给出了一个自定义函数(链接阅读原文),设定范围后,范围内的单元格都会合并,并且应用样式,就像是单个cell一样。在这里就不多赘述了,有兴趣的可以看看。很实用

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20181225A0QTLE00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券