openxlpy学习笔记

1. 生成Excel文件对象

语法格式:文件对象 = openpyxl.load_workbook('文件名')

利用该方法打开一个Excel文件,并生成workbook对象,该对象用于操作打开的Excel文件

2.1 通过表名得到表对象

语法格式:表对象 = 文件对象['表名']

2.2 获取活动表对象

语法格式:表对象 = 文件对象.active

3. 获取表格中数据所占大小

语法格式:表对象.dimensions

该方法可以得到表格中数据占据了几行几列,如:5行5列 就表示为 A1:E5

4. 获取单元格中的数据

语法格式:单元格对象.value

通过该方法得到该单元格内的数据

5. 通过指定行和列,获得单元格对象

语法格式:单元格对象 = 表对象.cell(row=,column=)

其中,row表示行,column表示列,通过该方法可以得到第几行第几列的单元格对象

注意:

获取的单元格内没有数据,返回的结果为 None

6.获取表中单元格的行、列、坐标

语法格式:

1、单元格对象.row :得到该单元格是第几行

2、单元格对象.columns :得到该单元格是第几列

3、单元格对象.coordinate:得到该单元格的坐标

python 复制代码
# 导入模块
import openpyxl

# 1、打开文件,生成文件对象
workbook = openpyxl.load_workbook('test.xlsx') # 这里文件名,也可以是文件路径,如:D:day/test.xlsx
# 注意:该文件必须存在,不然会报错
# 2、获取活动表对象
sheet = workbook.active
# 3、得到指定单元格对象
cell1 = sheet.cell(row=3,column=2) # 表示获得第3行第2列的单元格对象
cell2 = sheet['C2'] # 表示得到B3位置的单元格对象

# 4、获得单元格的行、列、坐标
print(cell1.row, cell1.column, cell1.coordinate) # 输出结果:3 2 B3
print(cell2.row, cell2.column, cell2.coordinate) # 输出结果:2 3 C2
7. 获取指定区间的数据

语法格式:表对象.['区间'],如:sheet.['A1:A5']

通过该方法可以得到区间范围内的所有单元格对象,以元组的形式返回,通过这些对象可以得到其单元格对应的数据

8.获取指定行或列的数据

语法格式:

1、表对象.['A']:表示获取第A列所有单元格对象

2、表对象.['A:C']:表示获取A、B、C三列所有单元格对象

3、表对象.[2]:表示获取第2行所有单元格对象

注意:只会获取到有数据的单元格对象

9.按行或按列读取单元格数据(迭代器)

语法格式:

1、表对象.iter_rows(min_row=,max_row,min_col=,max_col=),按找顺序一行一行的读取数据

2、表对象.iter_cols(min_row=,max_row,min_col=,max_col=),按照顺序一列一列的读取数据

参数说明:

min_row:表示从第几行开始读取

max_row:表示读取到第几行借结束

min_col:表示从第几列开始读取

max_col:表示读取到第几列结束

python 复制代码
# 导入模块
import openpyxl

# 1、打开文件,生成文件对象
workbook = openpyxl.load_workbook('test.xlsx') # 这里文件名,也可以是文件路径,如:D:day/test.xlsx
# 注意:该文件必须存在,不然会报错
# 2、获取活动表对象
sheet = workbook.active
print(f'当前活动表为:{sheet}')

# 3、按行的顺序读取数据
data1 = sheet.iter_rows(min_row=2,max_row=4,min_col=1,max_col=2) # data接收的是这块区间单元格对象
print(f'行区间单元格对象:{data1}')
# 将读取的数据通过for循环遍历出来,需要两个for循环
print('按行的顺序读取的数据:')
for i in data1:
    for x in i:
        print(x.value)

# 4、按列的顺序读取数据
data2 = sheet.iter_cols(min_row=2,max_row=4,min_col=1,max_col=2) # data接收的是这块区间单元格对象
print(f'列区间单元格对象:{data2}')
# 将读取的数据通过for循环遍历出来,需要两个for循环
print('按列的顺序读取的数据:')
for i in data2:
    for x in i:
        print(x.value)
python 复制代码
当前活动表为:<Worksheet "Sheet1">
行区间单元格对象:<generator object Worksheet._cells_by_row at 0x000001D8757D3DD0>
按行的顺序读取的数据:
张三
唱
李四
跳
王五
rap
列区间单元格对象:<generator object Worksheet._cells_by_col at 0x000001D8757D3F90>
按列的顺序读取的数据:
张三
李四
王五
唱
跳
rap
10.获取表中数据所占的行列数

语法格式:

1、表对象.max_row,获取到表中数据有几行

2、表对象.max_column,获取到表中数据有几列

11. 获取到表中所有行和列的数据

语法格式:

1、表对象.rows:获取表中所有行的对象

2、表对象.columns:获取表中所有列的对象

只会获取到有数据的行和列

本文参考自:python之openpyxl模块和CSV模块------实现Excel表格的处理(万字教学,全网最全,超详细!!!)-CSDN博客

相关推荐
星火开发设计几秒前
C++ deque 全面解析与实战指南
java·开发语言·数据结构·c++·学习·知识
saoys5 分钟前
Opencv 学习笔记:图像膨胀 / 腐蚀(附滑块动态调节腐蚀核大小)
笔记·opencv·学习
hhcccchh10 分钟前
学习vue第十天 V-Model学习指南:双向绑定的魔法师
前端·vue.js·学习
专注于大数据技术栈1 小时前
java学习--Collection的迭代器
java·python·学习
气概10 小时前
法奥机器人学习使用
学习·junit·机器人
Qhumaing10 小时前
C++学习:【PTA】数据结构 7-1 实验7-1(最小生成树-Prim算法)
c++·学习·算法
好大哥呀11 小时前
Java Web的学习路径
java·前端·学习
梦雨羊13 小时前
Base-NLP学习
人工智能·学习·自然语言处理
丝斯201113 小时前
AI学习笔记整理(42)——NLP之大规模预训练模型Transformer
人工智能·笔记·学习
小猪佩奇TONY13 小时前
Linux 内核学习(14) --- linux x86-32 虚拟地址空间
linux·学习