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')

posted @   古兴越  阅读(2133)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示