百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python拆分Excel合并单元格并填充相同内容

off999 2024-12-17 15:42 31 浏览 0 评论

实现目标:

将excel中带有合并单元格的数据,进行拆分合并单元格并填充相同的数据。

完整代码:

import openpyxl
def merged_cells(old,new):

    workbook = openpyxl.load_workbook(old)  #加载已经存在的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坐标信息
    # print(m_list)
    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
        # print(m_area)
        # print(r1,r2,c1,c2)
        # 纵向合并单元格的位置信息提取出
        cr.append((r1, r2, c1, c2))
        # print('符合条件%s' % str(m_area))

    # 这里注意需要把合并单元格的信息提取出再拆分
    print(cr)
    for r in cr:
        # print(r)
        worksheet.unmerge_cells(start_row=r[0], end_row=r[1],
                                start_column=r[2], end_column=r[3])
        # print(r[0])
        # for r1,r2,c1,c2 in range([r[0], r[1],r[2],r[3]]):
            # print(row)
    for r in cr:
        print(r)
        for row in range(r[0],r[1]):
            rown=row + 1
            worksheet.cell(row=rown, column=r[3], value=worksheet.cell(r[0], r[3]).value)
            print('填充',rown,r[3])
            for col in range(r[2],r[3]+1):
                worksheet.cell(row=row + 1, column=col, value=worksheet.cell(r[0], r[2]).value)
                print('填充',row + 1,col)
        if r[0]==r[1]:
            for col in range(r[2],r[3]+1):
                worksheet.cell(row=r[0], column=col, value=worksheet.cell(r[0], r[2]).value)
                print('填充',r[0],col)
        workbook.save(new)


if __name__ == '__main__':
    old=r'C:\Users\yellow\Documents\测试合并单元格.xlsx'
    save = r'C:\Users\yellow\Documents\test.xlsx'
    merged_cells(old,save)

核心步骤:

一、定位到合并单元格的区域

二、找到合并单元格的4个点

三、用左上角的数据填充其他区域的数据(1、会涉及到相同行的合并单元格。2、会涉及到相同列的合并单元格。3、多行多列的合并单元格)

操作合并单元格,极大地提高了手动点击的效率,并且不容易人工的遗漏其他合并单元格。

相关推荐

mail163邮箱登录入口网页版(mail163手机邮箱登录)

1.首先你要开启网易的POP3/SMTP/IMAP。2.设置完之后你需要网易的客户端授权密码。3.密码会发送至你的绑定手机。4.用发给你的客户端授权密码登录第三方客户端(ios客户端)5.直接登陆,储...

微信一键恢复(微信一键恢复已删好友怎么操作)
  • 微信一键恢复(微信一键恢复已删好友怎么操作)
  • 微信一键恢复(微信一键恢复已删好友怎么操作)
  • 微信一键恢复(微信一键恢复已删好友怎么操作)
  • 微信一键恢复(微信一键恢复已删好友怎么操作)
win7系统序列号怎么查(win7电脑的序列号怎么查)

你可以在cmd命令行窗口中输入以下相关命令,可以得到你要的信息查找主板厂商输入:wmicBaseBoardgetManufacturer查找主板型号输入:wmicBaseBoardgetP...

台式电脑怎么看配置好坏(台式机怎么看配置参数哪里看好坏)

如何分辨电脑配置好坏第一看CPU,CPU从上到下可分为i7,i5,i3等,数字越高越好。第二看显卡和内存,显卡内存现在至少4G或者8G起步,越高越好,第三看硬盘是否是固态,固态要比机械的运行速度快...

下载软件安装不了(为什么下载软件安装不了)

    一:检查手机内存是否充足,如果内存太小,需要更换大容量的SD卡。  二:检查手机是否设置允许安装除手机自带应用商店以外的应用。  方法一:需要从手机自带应用商店下载。  ①点击手机桌面上的应用...

现在建议更新win11吗(应该升级win11吗)

鲁大师更新11靠谱的,他只是给你提供一个方便的升级渠道而已。升级以后能否正常使用,还要看你原来的系统是否是正版。如果原来的系统是正版,升级完成后,可以正常使用。如果原来的系统是盗版,也是可以升级的,只...

windows7旗舰版好用吗(win7旗舰版好用么)

win7旗舰版挺好使的不过现在可以选择更win10。Windows7旗舰版属于微软公司开发的Windows7操作系统系统系列中的功能最高级的版本,也被叫做终结版本,是为了取代WindowsXP...

2025年最好用的手机浏览器(2021最好的手机浏览器)

可以使用uc浏览器或者是QQ浏览器,最新版本都是带有Flash插件的,火狐浏览器手机版也是一开始拥有Flash插件。以下是详细介绍:  1、uc浏览器是阿里旗下的浏览器,只需要下载最新版,然后进去就可...

电脑一键还原系统在哪里(电脑一键还原系统怎么用)
  • 电脑一键还原系统在哪里(电脑一键还原系统怎么用)
  • 电脑一键还原系统在哪里(电脑一键还原系统怎么用)
  • 电脑一键还原系统在哪里(电脑一键还原系统怎么用)
  • 电脑一键还原系统在哪里(电脑一键还原系统怎么用)
纯净版win11在哪下载(在哪下win10纯净版)

Win11纯净版中,有一些常用的应用软件,包括但不限于以下几款:MicrosoftEdge:微软推出的新一代浏览器,支持多种设备,具备更快的加载速度和丰富的扩展功能。MicrosoftOffice...

电脑软件最全的应用商店(电脑软件最全的应用商店下载)
  • 电脑软件最全的应用商店(电脑软件最全的应用商店下载)
  • 电脑软件最全的应用商店(电脑软件最全的应用商店下载)
  • 电脑软件最全的应用商店(电脑软件最全的应用商店下载)
  • 电脑软件最全的应用商店(电脑软件最全的应用商店下载)
win7自带激活工具在哪个位置

恩,其实这些就是激活系统的工具,朋友可以通过计算机属性看看你的系统是不是激活了。如果没有的话,建议你使用OEM7F7那个,使用方法是右键,以管理员身份运行,然后点击开始体验正版,等下,重新启动系统...

无法激活因为无法连接到组织

 解决方法: 首先我们右键点击“开始菜单”,选择“WindowsPowerShell(管理员)”。 在windowsPowershell窗口中逐一输入如下三行命令,并回车键执行命令。 slmgr...

一个2tb的u盘多少钱(2tb优盘)

假的就算你买回来插到电脑上显示是2TB也没用,你复制东西到U盘里就会显示U盘已满不能复制,就算复制进去了也会有一部分不能使用。或者你买回来用360的U盘鉴定软件鉴定一下就知道真假了。还有就是你看看...

软件商店下载官方网站(软件商店正版软件下载)

软件商店安装的方法步骤如下:1.第一步,需要注册一个微软账户,然后点击桌面左下角的开始图标,然后在开始菜单中找到微软商店图标,点击进入。2.第二步,点击进入应用商店主页。3.第三步,在商店中搜索...

取消回复欢迎 发表评论: