python使用openpyxl excel 合并拆分单元格

再次编辑中,这次是在使用删除列的时候发现,合并单元格会出现漏删除情况,才想到用拆分单元格,没想到unmerge_cells(),worksheet.merged_cells返回的合并单元格对象居然不能迭代,

函数参数也变了,居然可以直接上参数;;openpyxl=Version: 2.5.9;

列 :worksheet.delete_cols(2, 1) 表示第二列开始,删除一列 ,行worksheet.delete_rows(2, 1)

worksheet.unmerge_cells(start_row=1, start_column=7, end_row=2, end_column=7)

表示第一行开始,第二行结束, 低7列开始第七列结束, 就是把G1:G2合并的单元格给拆分了,下面的是合并单元格就不多说了

worksheet.merge_cells(start_row=1, start_column=2, end_row=2, end_column=2)

使用 openpyxl 库拆分已经合并的单元格;主要是使用了:

worksheet.merged_cells获取已经合并单元格的信息;再使用worksheet.unmerge_cells()拆分单元格;

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import openpyxl

workbook = openpyxl.load_workbook(path)  #加载已经存在的excel
# workbook = openpyxl.Workbook(path)
name_list = workbook.sheetnames
# worksheet = workbook.get_sheet_by_name(name_list[0])  #最新版本已经不能使用这种方法
worksheet = workbook[name_list[0]]


m_list = worksheet.merged_cells  #合并单元格的位置信息,可迭代对象(单个是一个'openpyxl.worksheet.cell_range.CellRange'对象),print后就是excel坐标信息
cr = []
for m_area in m_list:
    # 合并单元格的起始行坐标、终止行坐标。。。。,
    r1, r2, c1, c2 = m_area.min_row, m_area.max_row, m_area.min_col, m_area.max_col
    # 纵向合并单元格的位置信息提取出
    if r2 - r1 > 0:
        cr.append((r1, r2, c1, c2))
        print('符合条件%s' % str(m_area))

# 这里注意需要把合并单元格的信息提取出再拆分
for r in cr:
    worksheet.unmerge_cells(start_row=r[0], end_row=r[1],
                            start_column=r[2], end_column=r[3])

workbook.save(path)

再使用 worksheet.unmerge_cells()输入参数的时候,若和worksheet.merged_cells的结果放到同一个循环;

经常出现有些单元格拆分没有完成(实际上可以多次运行就可以完成了),我估计是再拆分单元格的时候有数据动态的改变了,

导致(再执行m_area.min_row时)m_list中的openpyxl.worksheet.cell_range.CellRange对象动态获取值时发生了改变;

只好把位置信息提取出,再调用;后面我测试过m_list对象deepcopy一份就可以了;

from copy import deepcopy
l = deepcopy(m_list)
for m_area in l:# 合并单元格的起始行坐标、终止行坐标。。。。,
    r1, r2, c1, c2 = m_area.min_row, m_area.max_row, m_area.min_col, m_area.max_col
    if r2 - r1 > 0:
        worksheet.unmerge_cells(start_row=r1, end_row=r2,
                                start_column=c1, end_column=c2)
  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值