原excel有合并单元格这种格式,openpyxl打开然后保存边框消失的问题

python3.5 openpyxl2.5可以用这个文件解决

文件名为:fix_border.py,代码见下面的代码片

在你写代码的那个文件里导入该文件
from fix_border import patch_worksheet
然后在load文件前加上patch_worksheet()
全部代码为

    ws = opx.load_workbook(filename1)
     fix_border.patch_worksheet()
    ws.save(filename2)

fix_border.py代码为

# -*- coding:utf-8 -*-
from itertools import product
import types
import openpyxl
from openpyxl.utils import get_column_letter
from openpyxl import worksheet
from openpyxl.utils import range_boundaries
from itertools import product
import regex as re
def patch_worksheet():
    """This monkeypatches Worksheet.merge_cells to remove cell deletion bug
    https://bitbucket.org/openpyxl/openpyxl/issues/365/styling-merged-cells-isnt-working
    Thank you to Sergey Pikhovkin for the fix
    """

    def merge_cells(self, range_string=None, start_row=None, start_co
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 14
    评论
将多个Excel文件的内容合并,保持内容格式不变,可以使用Python中的`openpyxl`库。 下面是一个示例代码,将多个Excel文件的内容合并到一个新的Excel文件中: ```python from openpyxl import load_workbook from openpyxl.utils import get_column_letter # 创建一个新的Excel文件 merged_wb = Workbook() # 遍历所有要合并Excel文件 for file in ['file1.xlsx', 'file2.xlsx', 'file3.xlsx']: # 读取当前Excel文件 wb = load_workbook(filename=file) sheets = wb.sheetnames # 遍历当前Excel文件的所有工作表 for sheet_name in sheets: sheet = wb[sheet_name] # 遍历当前工作表的所有行和列 for row in sheet.iter_rows(): new_row = [] for cell in row: col_letter = get_column_letter(cell.column) addr = col_letter + str(cell.row) new_cell = merged_wb[sheet_name][addr] new_cell.value = cell.value new_row.append(new_cell) # 在新的Excel文件中添加当前行的数据 merged_wb[sheet_name].append(new_row) # 保存新的Excel文件 merged_wb.save('merged_file.xlsx') ``` 在这个示例代码中,我们首先使用`openpyxl`库创建一个新的Excel文件,然后遍历要合并的所有Excel文件和工作表,并将它们的数据逐行逐列复制到新的Excel文件中。 需要注意的是,为了保持内容格式不变,我们需要使用原始单元的样式和格式,并在新的Excel文件中创建新的单元来存储原始单元的值和样式。在上面的示例代码中,我们使用了`openpyxl`的`iter_rows()`函数来遍历每一行和每一列,并使用`get_column_letter()`函数获取列字母,然后使用`addr`变量获取当前单元的地址。最后,我们将原始单元的值和样式复制到新的单元中,并将新的单元添加到新的Excel文件中。 这种方法可以保持原始Excel文件中的所有格式,包括字体、颜色、边框等。但是,由于需要逐行逐列复制数据,这种方法可能不适用于大型Excel文件。
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值