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

使用python3.5和openpyxl2.5时,发现打开含合并单元格的Excel文件并保存后,边框格式会丢失。通过引入fix_border.py中的patch_worksheet()函数在加载文件前进行修复,但删除行操作后,单元格格式仍可能混乱。openpyxl目前尚无官方解决方案,不过有一个更新的链接可能提供帮助:https://bitbucket.org/openpyxl/openpyxl/issues/700/cell-borders-lost-on-save。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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_column=None, end_row=None, end_column=None):
        """ S
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值