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()拆分單元格;

 

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)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM