Python中怎么使用openpyxl模块
这篇文章主要介绍“Python中怎么使用openpyxl模块”,在日常操作中,相信很多人在Python中怎么使用openpyxl模块问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python中怎么使用openpyxl模块”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
安装方法使用 pip 或通过专门 python IDE(如pyCharm)进行安装
基本使用其中pip安装方法,命令行输入: pip install openpyxl
第一步先是要导入 openpyxl 模块
importopenpyxl读取Excel文档
通过调用方法 load_workbook(filename) 进行文件读取,该方法中还有一个 read_only 参数用于设置文件打开方式,默认为可读可写,该方法最终将返回一个 workbook 的数据对象
#文件必须是xlsx格式,如果是其他格式在执行前可利用win32辅助转化wb=openpyxl.load_workbook(‘example.xlsx’)(一)获取工作表
每一个 Excel 表格中都会有很多张 sheet 工作表,在对表格操作前需要先选定一张工作表
#获取所有工作表名(返回一个列表)sheets=wb.get_sheet_names()#获取某一特定的工作表sheet=wb.get_sheet_by_name('Sheet2')#获取工作表的表名sheet_name=sheet.title#一般来说,表格大多数用到的是打开时显示的工作表,这时可以用active来获取当前工作表sheet=wb.active(二)获取单元格
对 Excel 表格的操作最终都落于对单元格的操作,获取单元格有两种获取方法:sheet[列行名]和 sheet.cell(row,column)
#通过sheet[列行名]获取a=sheet['A2']#通过sheet.cell(row,column)获取b=sheet.cell(1,2)#即sheet['B1']#获取单元格内容print(a.value)#获取单元格所在列和行print(‘ais’+str((a.column,a.row)))
需要注意的是,sheet.cell(row,column)中参数分别是行和列,且必须为整数,如果列为英文字母,可以利用openpyxl.utils中的column_index_from_string(char)进行字母数字的转化。顺便一说,同理也可以利用get_column_letter(number) 进行数字字母间的转化
fromopenpyxl.utilsimportget_column_letter,column_index_from_string#对列进行字母/数字转化c_num=column_index_from_string('B')#c_num=2c_char=get_column_letter(5)#c_char='E‘(三)获取行和列
在处理 Excel 表格有时可能需要对表格进行遍历查找,openpyxl 中便提供了一个行和列的生成器 (sheet.rows和sheet.columns) ,这两个生成器里面是每一行(或列)的数据,每一行(或列)又由一个 tuple 包裹,借此可以很方便地完成对行和列的遍历
#对行进行遍历,输出A1,B1,C1forrowinsheet.rows:forcellinrow:print(cell.value)#对列进行遍历,输出A1,A2,A3forcolumninsheet.columns:forcellincolumn:print(cell.value)
学习时还发现也可以通过 list(sheet.rows)index对某一行或列进行遍历,而在此值得注意的是,由于sheet.rows(或sheet.columns)
是生成器类型,是不能直接调用的,需将其转化为一个 list 类型,然后再通过索引遍历
#对某一特定的行进行遍历forcellinlist(sheet.rows)[0]:print(cell.value)
同时,也可以通过使用 sheet[行列值:行列值] 来对给定单元格范围进行遍历
#对某一单元格范围进行遍历forspacesinsheet['A1':'B2']:forcellinspaces:print(cell.value)
另外,有时候我们还可能需要确定表格的大小,即获取表格行和列的最大值,可以用max_row和max_column来获取
#获得最大列和最大行print(sheet.max_row)print(sheet.max_column)写入Excel文档
在开头读取时已经介绍,默认的打开方式为可读可写,那么使用 load_workbook(filename) 读取 Excel 文档后也就可以直接写入了。另外,如果需要新建一个 Excel 文件,可以使用 Workbook()方法,同时它会自动提供一个 sheet 工作表。对于删除一个工作表,则可以使用 workbook 对象的 remove(sheet) 方法删除
#新建一个Excel文档wb=openpyxl.Workbook()#删除某个工作表wb.remove(sheet)(一)写入单元格
获取工作表和之前一样,如果使用 load_workbook(filename) 读取,那么获取工作表后可以直接通过sheet[行列值]写入单元格。学习时,有资料介绍还可以传入Excel中的公式进行赋值,不过要注意,在读取文件时需要加上参数 data_only=True ,这样才能返回数字,否则将返回字符串,即公式本身
#直接赋值sheet['A1'].value=2#公式赋值sheet['A6'].value='=SUM(A1:A5)'
另外,也可使用 sheet.append(parameters) 一行或多行写入
#写入一行row=[1,2,3,4,5]sheet.append(row)#写入多行rows=[['ID','Name','Department'],['001','Lee','CS'],['002','John','MA'],['003','Amy','IS']]sheet.append(rows)(二)保存文件
写完文件后,使用 workbook.save(path+filename)进行保存,不过要注意文件扩展名一定要是 xlsx 格式
#保存文件至当前目录wb.save('new_file.xlsx')设置单元格样式
单元格样式主要包括字体、边框、颜色以及对齐方式等,这些均位于 openpyxl.styles 库中
#导入字体、边框、颜色以及对齐方式相关库fromopenpyxl.stylesimportFont,Border,Side,PatternFill,colors,Alignment(一)字体
通过 sheet 单元格 font 属性设置字体风格
#设置字体风格为TimesNewRoman,大小为16,粗体、斜体,颜色蓝色sheet['A1'].font=Font(name='TimesNewRoman',size=16,bold=True,italic=True,color=colors.BLUE)(二)对齐方式
通过 sheet 单元格 alignment 属性设置文本对齐风格
#通过参数horizontal和vertical来设置文字在单元格里的对齐方式,此外设置值还可为left和rightsheet['B1'].alignment=Alignment(horizontal='center',vertical='center')(三)边框
通过 sheet 单元格 border 属性设置字体风格
#首先设置边框四个方向的线条种类left,right,top,bottom=[Side(style='thin',color='000000')]*4#再将各方向线条作为参数传入Border方法sheet['C1'].border=Border(left=left,right=right,top=top,bottom=bottom)(四)设置行高和列宽
行和列的长度大小可以通过 row_dimensions[序号].height 和 column_dimensions[标号].width 来设置
#设置行高sheet.row_dimensions[1].height=25#设置列宽sheet.column_dimensions['D'].width=15.5(五)合并和拆分单元格
对单元格的合并与拆分,主要是通过 sheet 的 merge_cells(args1:args2)和unmerge_cells(args1:args2) 两个方法来实现的
当然,除了对角矩形区域化合并,也可以对一行或一列进行合并,只需相应修改参数即可。不过,这里要注意的是,合并后单元格显示的文本内容是合并前最左上角单元格的内容,而其他单元格内容则会自动清除。
#合并单元格sheet.merge_cells('A1:B2')#拆分单元格sheet.unmerge_cells('A1:B2')
到此,关于“Python中怎么使用openpyxl模块”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。