Python是如何读取合并单元格的,方法是什么
Admin 2022-09-19 群英技术资讯 1211 次浏览
这篇文章给大家分享的是Python是如何读取合并单元格的,方法是什么。小编觉得挺实用的,因此分享给大家做个参考,文中的介绍得很详细,而要易于理解和学习,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。假设在test.xlsx的“Sheet1”工作表中,A1:D3区域的值如下:

要求给定指定的行、列以及对应的工作表作为参数,能够正确解析合并单元格,获取指定单元格的值。
如果直接根据行列获取对应单元格的值,则合并单元格非左上角的其他单元格都会获取到None值,如下:
if __name__ == "__main__":
wb = xl.load_workbook("test.xlsx")
sheet_ = wb["Sheet1"]
print(sheet_["A1"].value) # 1
print(sheet_["A2"].value) # None
print(sheet_["D1"].value) # 8
print(sheet_["D2"].value) # None
print(sheet_["D3"].value) # None
获取到对应单元格后,判断该单元格是否为合并单元格,如果是,则找到该合并区域并获取左上角的值返回。
通过 sheet.merged_cell_ranges属性,可以获取当前工作表所有的合并区域列表:
测试代码:
if __name__ == "__main__":
wb = xl.load_workbook("test.xlsx")
sheet_ = wb["Sheet1"]
merged_ranges = sheet_.merged_cell_ranges # 获取当前工作表的所有合并区域列表
for merged_range in merged_ranges:
print(type(merged_range)) # 打印区域对象类型
print(merged_range) # 打印区域
结果如下:

我们巡着openpyxl.worksheet.merge.MergedCellRange查找其源码,发现定义了in操作,可以直接通过in确认某个坐标是否位于区域内

这时候我们已经基本具备获取合并单元格的条件了。
完整代码如下:
import openpyxl as xl
from openpyxl.worksheet.worksheet import Worksheet
from openpyxl.cell import MergedCell
def parser_merged_cell(sheet: Worksheet, row, col):
"""
检查是否为合并单元格并获取对应行列单元格的值。
如果是合并单元格,则取合并区域左上角单元格的值作为当前单元格的值,否则直接返回该单元格的值
:param sheet: 当前工作表对象
:param row: 需要获取的单元格所在行
:param col: 需要获取的单元格所在列
:return:
"""
cell = sheet.cell(row=row, column=col)
if isinstance(cell, MergedCell): # 判断该单元格是否为合并单元格
for merged_range in sheet.merged_cell_ranges: # 循环查找该单元格所属的合并区域
if cell.coordinate in merged_range:
# 获取合并区域左上角的单元格作为该单元格的值返回
cell = sheet.cell(row=merged_range.min_row, column=merged_range.min_col)
break
return cell
if __name__ == "__main__":
wb = xl.load_workbook("test.xlsx")
sheet_ = wb["Sheet1"]
for row_index in range(1, 4):
for col_index in range(1, 5):
cell_ = parser_merged_cell(sheet_, row_index, col_index)
print("第%s行第%s列:%s" % (row_index, col_index, cell_.value))
结果如下:
第1行第1列:1
第1行第2列:2
第1行第3列:3
第1行第4列:8
第2行第1列:1
第2行第2列:4
第2行第3列:5
第2行第4列:8
第3行第1列:6
第3行第2列:7
第3行第3列:7
第3行第4列:8
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Requests是一常用的http请求库,它使用python语言编写,可以方便地发送http请求,以及方便地处理响应结果,下面这篇文章主要给大家介绍了关于python中Requests请求的安装与常见用法的相关资料,需要的朋友可以参考下
这篇文章主要为大家详细介绍了Python实现信息管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
itertools是python内置的模块,使用简单且功能强大。这篇文章就主要介绍了通过itertools实现可迭代对象的无限迭代、有限迭代和排列组合。感兴趣的同学可以关注一下
这篇文章主要介绍了Python asyncio的一个坑,文章从Python编程错误开始介绍,改变与好多变不成中常犯的错误,我们今天就来分析分析吧,需要的下伙伴也可以参考一下
Python基本数据类型一般分为:数字、字符串、列表、元组、字典、集合这六种基本数据类型。浮点型、复数类型、布尔型(布尔型就是只有两个值的整型)、这几种数字类型。列表、元组、字符串都是序列。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008