使用Python将Excel合并的单元格内容拆分到每一行中

最近遇到一个Excel表格的问题类似如下情况,需要把合并单元格之后的一年级拆分成每个行里面有一年级,一直做太麻烦,于是想用Python自动解决,百度了一堆代码没一个能直接用的,要不是就是一堆报错,所以想着还不如自己写一个Python解决。

 

import openpyxl

# 打开工作簿并获取sheet
wb = openpyxl.load_workbook('select.xlsx')
sheet = wb['Sheet1']

# 复制一份合并单元格集合的副本
merged_cells = set(sheet.merged_cells.ranges)

# 遍历每个合并单元格
for merged_cell in merged_cells.copy():
    # 获取合并单元格的值
    merged_value = sheet.cell(row=merged_cell.min_row, column=merged_cell.min_col).value

    # 拆分合并单元格
    sheet.unmerge_cells(str(merged_cell))

    # 将值分配给每个单元格
    for row in range(merged_cell.min_row, merged_cell.max_row + 1):
        for column in range(merged_cell.min_col, merged_cell.max_col + 1):
            cell = sheet.cell(row=row, column=column)
            cell.value = merged_value

# 保存工作簿
wb.save('new_select.xlsx')

有相应的注释,只要安装openpyxl包并输入需要的Excel文件和输出新的Excel文件格式即可直接运行,没有报错!!!

之后效果图就不放了,就是变成了每一行都有合并单元格里面的信息,如“一年级”“xx”这种,每一行都有了,很方便不用再用Excel指令做了。

### 使用Python拆分Excel表格中的垂直合并单元格 当面对含有垂直合并单元格Excel文件时,可以利用`openpyxl`来遍历这些单元格,并依据起始单元格内容填充其余被合并的部分。具体实现方式如下: 对于每一个检测到的合并区域,程序会获取其左上角第一个单元格(即合并区域的起始位置)的数据值作为整个区域内所有单元格的新值。此过程通过循环访问指定范围内的每一行和列完成。 ```python from openpyxl import load_workbook path = "E:\\workspace\\temp\\test.xlsx" book = load_workbook(filename=path) sheet_ranges = book.active # 获取活动的工作表 for merged_cell in list(sheet_ranges.merged_cells): # 遍历所有的合并单元格 min_col, min_row, max_col, max_row = merged_cell.min_col, merged_cell.min_row, merged_cell.max_col, merged_cell.max_row start_cell_value = sheet_ranges.cell(row=min_row, column=min_col).value # 起始单元格的值 for row_index in range(min_row, max_row + 1): for col_index in range(min_col, max_col + 1): current_cell = sheet_ranges.cell(row=row_index, column=col_index) if not (row_index == min_row and col_index == min_col): # 排除起始单元格本身 current_cell.value = start_cell_value sheet_ranges.unmerge_cells(start_row=min_row, start_column=min_col, end_row=max_row, end_column=max_col) # 解除合并状态 # 保存修改后的文档至新路径 new_path = "E:\\workspace\\temp\\test_unmerged.xlsx" book.save(new_path) book.close() ``` 上述代码片段展示了如何读取一个存在合并单元格Excel文件,逐一遍历其中的每个合并区域,并按照规则分配相应的数据给各个单独的单元格,最后解除原有的合并设置[^1]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值