Python Excel 單元格 拆分並填充內容,功能和的wps類似


原文:https://www.cnblogs.com/liuda9495/p/9039732.html

一、實現的功能:





二、效果

1、拆分並填充前



2、拆分並填充后





三、代碼

import openpyxl
from copy import deepcopy


# 原文:https://www.cnblogs.com/liuda9495/p/9039732.html



path='test1.xlsx'
workbook = openpyxl.load_workbook(path)# 加載excel
name_list = workbook.sheetnames# 所有sheet的名字
worksheet = workbook[name_list[0]]# 讀取第一個工作表


# 獲取所有 合並單元格的 位置信息
# 是個可迭代對象,單個對象類型:openpyxl.worksheet.cell_range.CellRange
# print后就是excel坐標信息
m_list = worksheet.merged_cells



l = deepcopy(m_list)# 深拷貝


# 拆分合並的單元格 並填充內容
for m_area in l:
    
    # 這里的行和列的起始值(索引),和Excel的一樣,從1開始,並不是從0開始(注意)
    r1, r2, c1, c2 = m_area.min_row, m_area.max_row, m_area.min_col, m_area.max_col
        
    worksheet.unmerge_cells(start_row=r1, end_row=r2, start_column=c1, end_column=c2)
    print('區域:', m_area, '  坐標:', r1, r2, c1, c2)
    
    # 獲取一個單元格的內容
    first_value = worksheet.cell(r1, c1).value

    # 數據填充
    for r in range(r1, r2+1):# 遍歷行        
        if c2 - c1 > 0:# 多個列,遍歷列
            for c in range(c1, c2+1):
                worksheet.cell(r, c).value = first_value
        else:# 一個列
            worksheet.cell(r, c1).value = first_value


workbook.save('test2.xlsx')


免責聲明!

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



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