文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

python—xlwt模块详解

2023-09-04 13:40

关注

一、前言

xlwt模块是python中专门用于写入Excel的拓展模块,可以实现创建表单、写入指定单元格、指定单元格样式等人工实现的功能,一句话就是人使用excel实现的功能,这个扩展包都可以实现。

二、基础操作

1、创建workbook(创建excel)

#创建一个工作簿对象,设置编码格式为“utf-8”,默认格式是ASCII,为了方便写入中文,一般都要设置成UTF-8workBook = xlwt.Workbook(encoding='utf-8')

2、创建sheet表

# 通过工作薄对象创建sheet,sheetName 要求长度小于31个字符,并且不能存在斜杠,否则会报错sheet = workBook.add_sheet("sheetName")

3、写入数据

#首先需要在第0行写入表头,然后再写入后续数据,但是都是使用的write方法写入,只是坐标不一样head = ['姓名''年龄''性别']data = [['张三''19''男']['刘雯雯''18''女']]#循环写入表头for i in head:sheet.write(0,head.index(i),i)#循环写入数据for i in range(len(data)):    for j in range(len(data[i])):        sheet.write(i+1,j,data[i][j])

4、保存workbook

# 通过workBook对象的save方法保存文档,savePath可以是绝对路径,也可以是相对了路径savePath = 'C:\\Users\\Administrator\\Desktop\\test.xls'workBook.save(savePath)

上面的示例代码综合后如下:

import xlwtworkBook = xlwt.Workbook(encoding='utf-8')sheet = workBook.add_sheet("sheetName")head = ['姓名','年龄','性别']data = [['张三','19','男'],['刘雯雯','18','女']]for i in head:sheet.write(0,head.index(i),i)for i in range(len(data)):    for j in range(len(data[i])):        sheet.write(i+1,j,data[i][j])savePath = 'C:\\Users\\Administrator\\Desktop\\test.xls'workBook.save(savePath)

运行效果如下:

在这里插入图片描述

三、样式优化

1、设置行列宽度

1)设置列的宽度

在表格之中行是按照数字来计算,列是按照英文字母顺序来计算的。但是在xlwt库中则是将它们都改成从0开始,类似于索引的对象获取方式。调用sheet.col(0)就可以获取到表格列对象,它表示的就是列A。然后设置width属性值即可修改列宽,xlwt中默认字体0的1/256为衡量单位。xlwt创建时使用的默认宽度为2960,既11个字符0的宽度。

所以我们在设置列宽时可以用如下方法:width = 256 * 20 256为衡量单位,20表示20个字符宽度。

示例代码

for i in range (len(head)):sheet.col(i).width = 256*20

2)设置行的高度

行高的修改方式和列宽实际上是差不多的,使用row()方法并且传入索引即可获取到行对象。然后调用set_style()方法去设置行样式。

示例代码:

for i in range(len(data)):sheet.row(i+1).set_style(xlwt.easyxf('font:height 512;')) #第0行为表头,不修改

综合操作结果:

在这里插入图片描述

2、设置文本居中

在xlwt中,需要使用Alignment来设置单元格的对齐方式,其中horz代表水平对齐方式,vert代表垂直对齐方式。

示例:

style = xlwt.XFStyle()  # 创建一个样式对象,初始化样式al = xlwt.Alignment()al.horz = 0x02      # 设置水平居中al.vert = 0x01      # 设置垂直居中style.alignment = alfor i in range(len(data)):    for j in range(len(data[i])):sheet.write(i+1, j, data[i][j], style)

测试效果:

在这里插入图片描述

3、设置边框

xlwt要设置边框,需要使用Borders来设置,可以设置实线、虚线、没有边框三种,并且可以通过colour属性设置颜色。

示例:

style = xlwt.XFStyle()  # 创建一个样式对象,初始化样式borders = xlwt.Borders()#设置边框属性实线、黑色borders.left = xlwt.Borders.THINborders.top = xlwt.Borders.THINborders.right = xlwt.Borders.THINborders.bottom = xlwt.Borders.THINborders.left_colour = 0xffborders.right_colour = 0xffborders.bottom_colour = 0xffborders.top_colour = 0xffstyle.borders = bordersfor i in range(len(data)):    for j in range(len(data[i])):sheet.write(i+1, j, data[i][j], style)

测试效果:

在这里插入图片描述

4、设置字体样式

设置字体样式,需要使用Font()来创建字体样式。

示例:

style = xlwt.XFStyle() # 初始化样式font = xlwt.Font() # 为样式创建字体font.name = 'Times New Roman'font.bold = True # 黑体font.underline = True # 下划线font.italic = True # 斜体字style.font = font # 设定样式

测试效果:

在这里插入图片描述

5、综合代码

import xlwtworkBook = xlwt.Workbook(encoding='utf-8')sheet = workBook.add_sheet("sheetName")head = ['姓名', '年龄', '性别']data = [['张三', '19', '男'], ['刘雯雯', '18', '女']]for i in head:sheet.write(0, head.index(i), i)for i in range(len(head)):sheet.col(i).width = 256*20style = xlwt.XFStyle()  # 创建一个样式对象,初始化样式al = xlwt.Alignment()borders = xlwt.Borders()font = xlwt.Font() #设置居中al.horz = 0x02      # 设置水平居中al.vert = 0x01      # 设置垂直居中#设置边框borders.left = xlwt.Borders.THINborders.top = xlwt.Borders.THINborders.right = xlwt.Borders.THINborders.bottom = xlwt.Borders.THINborders.left_colour = 0xffborders.right_colour = 0xffborders.bottom_colour = 0xffborders.top_colour = 0xff# 设置字体样式font.name = 'Times New Roman'font.bold = True # 黑体font.underline = True # 下划线font.italic = True # 斜体字# 设定样式style.font = font style.alignment = alstyle.borders = borders# 写入数据和样式for i in range(len(data)):    sheet.row(i+1).set_style(xlwt.easyxf('font:height 512;'))    for j in range(len(data[i])):        sheet.write(i+1, j, data[i][j], style)# 保存工作薄savePath = 'C:\\Users\\Administrator\\Desktop\\test.xls'workBook.save(savePath)

来源地址:https://blog.csdn.net/qq_45590334/article/details/129158903

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯