十分钟教会你使用Python操作excel,内附步骤和代码

这篇文章主要介绍了python使用openpyxl操作excel的方法步骤 , 详细的介绍了openpyxl的常用属性以及操作excel的方法 , 感兴趣的可以了解一下
一 前言
放大招了 , 学完这篇openpyxl第三方库 , 读者将会懂得如何灵活的读取excel数据,如何创建excel工作表;更新工作表 , 删除工作表;是不是感觉很强大 , 留下赞赞吧!!
二 openpyxl常用属性函数
十分钟教会你使用Python操作excel,内附步骤和代码文章插图
三 读取excel
读取整体流程如下

  1. 加载工作本
  2. 获取标签页
  3. 获取指定区域的单元格
  4. 获取单个单元格对象
  5. 通过单元格对象获取值
3.1 准备工作
创建一个名为zszxz.xlsx excel文件;其中标签sheet名为zszxz; 列A B C 如下;
id num name1 100 zszxz2 101 smile3 102 kitty4 103 wolf5 104 cloud6 105 water3.2 安装
支持操作excel和图像
pip install openpyxlpip install pillow3.3 获取所有标签页名称
# -*- coding: utf-8 -*-import openpyxlpath = r'C:\mydata\generator\py\zszxz.xlsx'# 加载工作本workbook = openpyxl.load_workbook(path)# 获得所有标签页sheet_names = workbook.get_sheet_names()print(sheet_names)输出
['zszxz']
正确的获取方式
# -*- coding: utf-8 -*-import openpyxlpath = r'C:\mydata\generator\py\zszxz.xlsx'# 加载工作本workbook = openpyxl.load_workbook(path)# 获得所有标签页名称print(workbook.sheetnames)3.4 获取指定标签页对象
不建议通过方法获得标签页对象 , 建议通过属性方式获取;
# -*- coding: utf-8 -*-import openpyxlpath = r'C:\mydata\generator\py\zszxz.xlsx'# 加载工作本workbook = openpyxl.load_workbook(path)# 获得指定的sheetsheet = workbook.get_sheet_by_name('zszxz')print(sheet)输出

正确的获取方式
# -*- coding: utf-8 -*-import openpyxlpath = r'C:\mydata\generator\py\zszxz.xlsx'# 加载工作本workbook = openpyxl.load_workbook(path)# 获取sheet对象sheet = workbook['zszxz']print(sheet)
输出

当然读者也可以通过循环工作本方式获取sheet , 不赘述;
3.5 复制sheet
在已有的sheet上可以进行复制一个副本;
# -*- coding: utf-8 -*-import openpyxlpath = r'C:\mydata\generator\py\zszxz.xlsx'# 加载工作本workbook = openpyxl.load_workbook(path)# 获取sheet对象sheet = workbook['zszxz']# 复制sheetcp_sheet = workbook.copy_worksheet(sheet)print(cp_sheet)输出

3.5 获取指定一个单元格对象
指定获取A1单元格对象
# -*- coding: utf-8 -*-import openpyxlpath = r'C:\mydata\generator\py\zszxz.xlsx'# 加载工作本workbook = openpyxl.load_workbook(path)# 获取sheet对象sheet = workbook['zszxz']# 获取指定单元格cell = sheet['A1']print(cell)输出

方式二
# -*- coding: utf-8 -*-import openpyxlpath = r'C:\mydata\generator\py\zszxz.xlsx'# 加载工作本workbook = openpyxl.load_workbook(path)# 获取sheet对象sheet = workbook['zszxz']# 获取指定单元格cell = sheet.cell(row=1, column=1)print(cell)输出

3.6 访问多个单元格
访问单元格获取单元格对象;
# -*- coding: utf-8 -*-import openpyxlpath = r'C:\mydata\generator\py\zszxz.xlsx'# 加载工作本workbook = openpyxl.load_workbook(path)# 获取sheet对象sheet = workbook['zszxz']cells_range = sheet['A1':'C1']for cells in cells_range:for cell in cells:print(cell)输出

方式二
# -*- coding: utf-8 -*-import openpyxlpath = r'C:\mydata\generator\py\zszxz.xlsx'# 加载工作本workbook = openpyxl.load_workbook(path)# 获取sheet对象sheet = workbook['zszxz']# 获取指定范围的行row = sheet.iter_rows(min_row=1, max_col=3, max_row=1)for cell in row:print(cell)输出
(, , )
sheet.iter_cols(min_row, max_col, max_row)通用的道理 , 不赘述
3.7 获取全部行
# -*- coding: utf-8 -*-import openpyxlpath = r'C:\mydata\generator\py\zszxz.xlsx'# 加载工作本workbook = openpyxl.load_workbook(path)# 获取sheet对象sheet = workbook['zszxz']# 获取所有行for row in sheet.rows:print(row)输出
(, , )(, , )(, , )(, , )(, , )(, , )(, , )
同理 sheet.columns获取所有列不再赘述
3.8 获取值