openpyxl快速摸鱼手册

发布于 / 技术 / 0 条评论

最近在工作中一些地方需要生成Excel表格,虽然很简单就查到了这个Python使用的表格库,但是后续使用中还是有很多地方需要单独查找。现在简单记录一下写程序时用到的部分,以便以后查询。

在使用这个模块时,首先要引入模块。我进行了如下方法的引用:

在需要用到的地方,首先需要创建一个基本的工作表作为基础,使用下列代码会创建一个名为example.xlsx的空白工作簿,并把这个工作簿保存到Python程序的运行目录:

上述的方法可以创建一个空白的文件,但是每次执行的时候都会覆盖同名文件。接下来,为了生成表格,可以直接对cell对象进行赋值,也可以使用append方法直接添加一个list到新的行中:

现在,打开文件你会看见类似下表的数据:

Hello World!
I select this cell
The quick brown foxjumps overa lazy dog.

需要注意的是,append方法会默认选择一条最新的,没有修改过的轨道。我个人认为如果你合并了单元格可能也算在这个范围内。所以为了避免这种烦恼,我比较推荐预留一个空白格并在文档填写完毕后更新格式。下边来合并一个单元格说明为什么需要预留空格:

现在,我们新建了两行文本,并且合并了单元格作为测试,你打开文档后应该能看到这样的表格:

Hello World!
I select this cell
The quick brown foxa lazy dog.
The quick brown foxjumps overa lazy dog.

使用merge_cells()可以合并单元格,但是相应的,合并单元格后所有的单元格仅保留左上角数据,如果不预留空间的话就会发现表格中的内容直接消失了。

到这一步为止,我们已经可以约略的操作表格的格式了,接下来将要开始修改表格的外观,为了方便后续的理解,首先我们遍历一下现在的表格。可以使用下面的办法来获取表格中的每一个元素:

执行上边的程序,会将表格中每一个cell的数值都打印出来。在此基础上,我们先修改表格的字体,将他修改为“宋体,12号,加粗

这样就可以设置字体了,之后我们将每个表格的内容都设置为上下居中并给每个表格添加外边框:

现在,我们再次输出表格,就能看到表格中所有的数据都被设置成了居中对齐,宋体,12号,加粗,带边框的样式了。

接下来,我们来配置行高和列宽,在这里需要提一下Excel的概念:在Excel中的宽高单位不是采用像素规定的,而是和显示器、字体等有关,所以这个宽高是一个相对概念,而不是绝对概念。在案例中,我们会给AB两列设置为20,C设置为17,D设置为25。1行高15,2行高20,3,4行设为17

最后,我们给HelloWorld(A1)文字设置为黄色,背景设置为黑色:

当然,如果你完全按照教程复制粘贴的话,现在程序并不能运行,为了让程序可以运行,我们还需要一个很重要的东西。在你的代码下方添加一个主函数:

至此,这个教程就完全结束了,如果您全程按照教程进行的话,最后的文档应该和下边的截图一样:

就是这样!

玩的开心,祝你使用它在工作中更多摸鱼,更多快乐。

记得给我star

本网站在未特殊说明的情况下采用知识共享署名-非商业性使用-相同方式共享 3.0 协议进行许可。

<-数据丢失->