首页 > Python资料 博客日记
超详细讲解Python中openpyxl库
2024-08-09 23:00:05Python资料围观64次
目录
1.创建和保存工作簿
1.1创建工作簿
使用openpyxl没有必要先在系统中新建一个.xlsx,只需要引入Workbook这个类,接着开始调用它,并保存到指定位置。
工作簿 = openpyxl.Workbook("文件名称.xlsx")
工作簿.save(路径)
from openpyxl import Workbook
wb = Workbook()#新建工作簿
wb.save(r'C:\\Users\\ownWS\\Desktop\\newexcel.xlsx')
1.2打开工作簿
工作簿 = openpyxl.load_workbook("文件名称.xlsx")
工作表 = 工作簿['工作表名']
from openpyxl as vb
wb = vb.load_workbook()#1.打开工作簿
ws = wb['Sheet'] #2.指定工作表
1.3属性
属性 | 作用 |
active | 获取当前活跃的Woeksheet |
worksheets | 以列表的形式返回所有的Worksheet(表格) |
read_only | 判断是否以read_only模式打开excel文档 |
encoding | 获取文档的字符集编码 |
properties | 获取文档的元数据,如标题、创建者、创建日期 |
sheetnames | 获取工作簿中表(列表 |
1.4方法
方法 | 作用 |
工作簿.sheetnames | 获取所有表格的名字 |
工作簿['工作表名'] | 通过表格名字获取Woeksheet对象 |
工作簿.active | 获取活跃表格 |
remove | 删除一个工作表对象 |
create_sheet | 创建一个空的表格 |
copy_worksheet | 在Workbook内拷贝表格 |
一个工作簿(workbook)在创建的时候同时至少也新建了一张工作表(worksheet)。可以通过Workbook.active()调用得到正在运行的工作表。
ws = wb.active()
注意:该函数调用工作表的索引(_active_sheet_index),默认是0.除非修改这个值,否则会使用该函数一直是在对第一张工作表进行操作。
2.工作表的创建删除和复制
2.1从工作簿获取工作表
import openpyxl as vb
path = r'C:\Users\ownWS\Desktop\newexcel.xlsx'
wb = vb.load_workbook(path)
#显示所有工作表
ws = wb.worksheets
print(ws)
for i in ws:
print(i.title)#工作表名称
2.2删除工作表
wb.remove(worksheet)移除工作表
- worksheet为工作表对象,而非工作表名称
删除工作表的步骤
1.指定工作表
2.删除
3.保存
import openpyxl as vb
path = r'C:\Users\ownWS\Desktop\newexcel.xlsx'
wb = vb.load_workbook(path)
#删除工作表
sheet2 = wb['Sheet2']
wb.remove(sheet2)#删除工作表对象
wb.save(path)
注意:在创建工作簿的时候就已经自动创建一个名叫“Sheet”的工作表,首字母是大写的,移除工作表时,要先找到工作表对象wb['Sheet'],再把它放进renmove函数中进行移除
2.3创建工作表
wb.create_sheet(title = None,index = None)新建一张表
- title:工作表的名称,
- index:工作表的位置,默认放在最后
ws1 = wb.create_sheet() #默认插在工作簿末尾
#or
ws2 = wb.create_sheet(0)#插入在工作簿的第一个位置
ws3 = wb.create_sheet('表1',0)
2.4复制工作表
import openpyxl as vb
path = r'C:\Users\ownWS\Desktop\newexcel.xlsx'
wb = vb.load_workbook(path)
#复制工作表
copy_sheet = wb.copy_worksheet(wb['new title'])
wb.save(path)
2.4.1修改工作表名字
在创建工作表的时候系统自动命名。按照序列依次命名(Sheet,Sheet1,Sheet2,...)。可以通过调用下面属性修改工作表的名称:
ws.title = "new title"
2.4.2修改标签栏字体颜色
标签栏的背景色默认为白色,可以通过提供RRGGBB颜色码改变标签栏的字体颜色:
ws.sheet_properties.tabColor = "1072BA"
2.5属性
属性 | 作用 |
title | 工作表名称 |
dimensions | 表格的大小,这里的大小是指含有数据的表格的大小,即:左上角的坐标;右下角的坐标 |
max_row | 表格的最大行 |
min_row | 表格的最小行 |
max_column | 表格的最大列 |
min_column | 表格的最小列 |
rows | 按行获取单元格(Cell对象)-生成器 工作表.rows |
columns | 按列获取单元格(Cell对象)-生成器 工作表.columns |
freeze_panes | 冻结窗格 工作表.freeze_pannes = 'C3' |
values | 按行获取表格的内容(数据)-生成器 |
freeze_panes,参数比较特别,主要用于表格较大是冻结顶部的行或左边的列。
对于冻结的行,在用户滚动时,是始终可见的,可以设置为一个Cell对象或一个单元格坐标的字符串,单元格上面的行和左边的列将会冻结(单元格坐在的行和列不会被冻结)。
例如:
要冻结第一行,设置A2为freeze_panes,
要冻结第一列,设置B1为freeze_panes,
同时冻结第一行和第一列,设置B2为freeze_panes,
freeze_panes为None,表示不冻结任何列和行
2.6方法
方法 | 作用 |
iter_rows | 按行获取所有单元格,内置属性有(min_row,max_row,min_col,max_col) |
iter_columns | 按列获取所有单元格 |
append | 在表格末尾添加数据 |
merged_cells | 合并多个单元格 |
unmerged_cells | 移除合并的单元格 |
练习
1.批量生成工作表
import openpyxl as vb
path = r'C:\Users\ownWS\Desktop\test.xlsx'
wb = vb.Workbook(path)
for i in range(1,13):
wb.create_sheet(f'{"2024年"}{i}{"月"}')
wb.save(path)
2.批量修改工作表名字
import openpyxl as vb
path = r'C:\Users\ownWS\Desktop\test.xlsx'
wb = vb.load_workbook(path)
for i in wb.worksheets:
i.title = "北京" + i.title
wb.save(path)
持续更新中。。。。。。。。。。
标签:
相关文章
最新发布
- 光流法结合深度学习神经网络的原理及应用(完整代码都有Python opencv)
- Python 图像处理进阶:特征提取与图像分类
- 大数据可视化分析-基于python的电影数据分析及可视化系统_9532dr50
- 【Python】入门(运算、输出、数据类型)
- 【Python】第一弹---解锁编程新世界:深入理解计算机基础与Python入门指南
- 华为OD机试E卷 --第k个排列 --24年OD统一考试(Java & JS & Python & C & C++)
- Python已安装包在import时报错未找到的解决方法
- 【Python】自动化神器PyAutoGUI —告别手动操作,一键模拟鼠标键盘,玩转微信及各种软件自动化
- Pycharm连接SQL Sever(详细教程)
- Python编程练习题及解析(49题)
点击排行
- 版本匹配指南:Numpy版本和Python版本的对应关系
- 版本匹配指南:PyTorch版本、torchvision 版本和Python版本的对应关系
- Python 可视化 web 神器:streamlit、Gradio、dash、nicegui;低代码 Python Web 框架:PyWebIO
- 相关性分析——Pearson相关系数+热力图(附data和Python完整代码)
- Anaconda版本和Python版本对应关系(持续更新...)
- Python与PyTorch的版本对应
- Windows上安装 Python 环境并配置环境变量 (超详细教程)
- Python pyinstaller打包exe最完整教程