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博客

相关推荐
微露清风8 小时前
系统性学习Linux-第二讲-基础开发工具
linux·运维·学习
不会代码的小猴8 小时前
Linux环境编程第六天笔记--system-V IPC
linux·笔记
阳光九叶草LXGZXJ8 小时前
达梦数据库-学习-48-DmDrs控制台命令(同步之Manager、CPT模块)
linux·运维·数据库·sql·学习
乌恩大侠9 小时前
【笔记】USRP 5G 和 6G 参考架构
笔记·5g
biuyyyxxx9 小时前
Python自动化办公学习笔记(一) 工具安装&教程
笔记·python·学习·自动化
舟舟亢亢10 小时前
Java集合笔记总结
java·笔记
丝斯201110 小时前
AI学习笔记整理(66)——多模态大模型MOE-LLAVA
人工智能·笔记·学习
军军君0111 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
bylander12 小时前
【AI学习】TM Forum《Autonomous Networks Implementation Guide》快速理解
人工智能·学习·智能体·自动驾驶网络
kida_yuan12 小时前
【Linux】运维实战笔记 — 我常用的方法与命令
linux·运维·笔记