之前我们介绍过几个模块:xlrd、xlwt、XLsxWriter等,但是这些模块要门只能只读,要么只能只写,那么有没有即可读,也可写的模块,答案是肯定的,如pandas、openpyxl、文2com等,在此介绍其中一个:openpyxl。
openpyxl是一个用于读写Excel的模块,支持xlsx、xlsm、xltx、xltm等文件的读写,不支持xls格式,如果读取大的Excel文件,可以使用read_only(只读模式),如果写入大的Excel文件,可以使用write_only(只写模式)。
一、openpysx模块创建Excel文件4步法
1.1、Workbook():创建Excel文件
此函数是用来创建Excel文件的一个对象,返回的是一个对象,可以用此对象,创建工作表,保存文件等,如:
importopenpyxl#导入模块wb=Workbook()#生成Excel文件对象print(wb)
执行结果:
1.2、create_sheet("sheet_name"):创建工作表
openpyxl在创建Excel文件对象时,会默认创建一个名叫“sheet”的工作表,如果想生成工作表,则需要使用create_sheet()函数,可用wb.sheetnames属性查看所有工作表的名称,如:
importopenpyxl#导入模块wb=Workbook()#生成Excel文件对象print(wb.sheetnames)#默认生成的工作表sheetwb.create_sheet("new_sheet")print(wb.sheetnames)#增加了工作表new_sheet
执行结果:
备注:openpyxl在只写模式下,不会生成默认工作表,此时只能使用create_sheet()函数创建。
1.3、向工作表中添加内容
openpyxl添加内容比较接近Python语法,可以使用赋值语句"=",也可以使用append()语句(按行加入),如:
importopenpyxl#导入模块wb=Workbook()#生成Excel文件对象ws=wb.active#默认工作表sheet#添加内容(赋值语句)ws["A1"]=3ws["A2"]="helloworld"print(ws["A1"].value)print(ws["A2"].value)#添加内容(append语句),按行添加ws.append(["hellopython","hellojava","hellophp"])print(ws["A3"].value)print(ws["B3"].value)print(ws["C3"].value)
执行结果:
1.4、save("filename"):保存文件
当我们完成所有的操作后,就可以使用save()函数来保存我们创建的Excel文件,filename是文件名称及文件所保存的位置,如:
save("file/op/添加数据.xlsx")#保存文件
执行结果:
以上就是openpyxl创建Excel文件的4个步骤,相比于XLsxWriter模块,openpyxl在数据添加这块简单,方便,与python语法接近。
二、openpyxl读取Excel文件
openpyxl模块可以使用load_workbook("filename")方法来加载本地Excel文件,filename为文件路径,如:
importopenpyxl#导入模块wb=load_workbook("file/op/编程语言排名榜单.xlsx")#加载本地Excel文件ws=wb["2019年"]print("修改前B3的值:",ws["B3"].value)#打印单元格B3的值ws["B3"].value="HTML"#修改单元格B3的值print("修改后B3的值:",ws["B3"].value)#打印单元格B3的值
执行结果:
备注:openpyxl不能完全读取所有的内容,因此,如果本地Excel表格含有图片或者图表之类的,openpyxl是不能读取的,且在打开或者保存相同名称的Excel表格时,原先表格的图片或者图表将会丢失。
三、openpyxl进阶用法
3.1、合并和拆分单元格
3.1.1、merge_cells(*args):合并单元格
在openpyxl模块中,我们可以用merge_cells(start_row,start_column,end_row,end_column)方法来合并单元格,其中:
start_row:开始行
start_column:开始列
end_row:结束行
end_column:结束列
importopenpyxl#导入模块fromopenpyxl.stylesimportAlignment#导入格式模块wb=Workbook()#创建Excel文件对象ws=wb.active#选取当前sheet工作表ws.merge_cells(start_row=2,start_column=1,end_row=4,end_column=4)#合并单元格#也可以用ws.merge_cells("A2:D2")ws["A2"].alignment=Alignment(horizontal="center",vertical="center")#添加样式ws["A2"].value="合并单元格"#添加内容wb.save("file/op/合并单元格.xlsx")#保存文件
执行结果:
3.1.2、unmerge_cells():拆分单元格
与merge_cells()相反,在openpyxl模块中,我们可以用unmerge_cells(start_row,start_column,end_row,end_column)方法来拆分单元格,其中:
start_row:开始行
start_column:开始列
end_row:结束行
end_column:结束列
importopenpyxl#导入模块wb=load_workbook("file/op/合并单元格.xlsx")#加载本地Excel文件ws=wb.active#选取工作表格ws.unmerge_cells("A2:D4")#拆分单元格ws["A2"].value="拆分单元格"#添加内容wb.save("file/op/合并单元格.xlsx")#保存文件
执行结果:
3.2、行高和列宽
在openpyxl中,ws.row_dimensions["row_index"].height用于设置行高,ws.column_dimensions["col_index"]. width用于设置列宽,如:
importopenpyxl#导入模块wb=Workbook()#创建Excel文件对象ws=wb.active#选取工作表ws.row_dimensions[1].height=40#设置行高为40字符ws.column_dimensions["D"]. width=40#设置列宽为40字符ws["A1"]="行高为20个字符"#添加内容ws["D1"]="列宽为40个字符"#添加内容wb.save("file/op/设置行高和列宽.xlsx")
执行结果:
3.3、add_image(Image("image_path"),"cell"):插入图片
在openpyxl模块中,可以使用add_image()方法来向单元格添加图片,如:
importopenpyxl#导入模块fromopenpyxl.drawing.imageimportImage#导入图片模块wb=Workbook()#创建Excel文件对象ws=wb.active#选取工作表ws.add_image(Image("file/test.jpg"),"C3")#在C3单元格插入图片wb.save("file/op/插入图片.xlsx")
执行结果:
3.4、HYPERLINK("url","name"):添加链接
在openpyxl中,添加超链接很简单,使用HYPERLINK()即可向单元格里添加超链接,如:
importopenpyxl#导入模块fromopenpyxl.stylesimportFontwb=Workbook()#创建Excel文件对象ws=wb.active#选取工作表ws["C3"].font=Font(color='000000FF',i=True,underline='single')#超链接文字样式ws["C3"].value='=HYPERLINK("http://www.baidu.com","百度")'#添加超链接wb.save("file/op/添加链接.xlsx")#保存文件
执行结果:
3.4、样式设置
openpyxl样式设置主要有字体、填充、边框、对齐、数字格式、保护等,具体用法如下:
下面我们介绍几个:
importopenpyxl#导入模块wb=Workbook()#生成Excel文件对象print(wb.sheetnames)#默认生成的工作表sheetwb.create_sheet("new_sheet")print(wb.sheetnames)#增加了工作表new_sheet0
执行结果:
3.5、单元格属性获取
单元格的属性比较多,下面列举几个比较常用的,如下:
importopenpyxl#导入模块wb=Workbook()#生成Excel文件对象print(wb.sheetnames)#默认生成的工作表sheetwb.create_sheet("new_sheet")print(wb.sheetnames)#增加了工作表new_sheet1
执行结果:
3.6、单元格数据获取
单元格的数据获取可以使用value属性获取,如:
importopenpyxl#导入模块wb=Workbook()#生成Excel文件对象print(wb.sheetnames)#默认生成的工作表sheetwb.create_sheet("new_sheet")print(wb.sheetnames)#增加了工作表new_sheet2
执行结果:
以上为openpyxl的一些简单介绍,还有很多用法,在此就不一一介绍了,感兴趣的朋友,可以参考官方文档。