第一种方法

from openpyxl import load_workbook

workbook = load_workbook('excel.xlsx')
workbook._sheets = sorted(workbook._sheets)

网上找的,大家可以试试,我这边试了没什么用。

第二种方法

这种方法是本人自己探索出来的方法,其思路主要是将原先的表格中的每一个sheet按照我们想要的顺序依次复制到另一个新的表格中,以此达到排序的目的,不过也因此会产生一个新的表格。

def copy_sheet(wb, wb2, sheetnames):
	sheetnames = wb.sheetnames
    for sheetname in sheetnames:
        print(sheetname)
        sheet = wb[sheetname]
        sheet2 = wb2.create_sheet(sheetname)
        # tab颜色
        sheet2.sheet_properties.tabColor = sheet.sheet_properties.tabColor
        
        # 缩放比例
        sheet2.views.sheetView[0].zoomScale = sheet.views.sheetView[0].zoomScale

        # 开始处理合并单元格形式为“(<CellRange A1:A4>,),替换掉(<CellRange 和 >,)' 找到合并单元格
        wm = list(sheet.merged_cells)
        if len(wm) > 0:
            for i in range(0, len(wm)):
                cell2 = str(wm[i]).replace('(<CellRange ', '').replace('>,)', '')
                sheet2.merge_cells(cell2)

        for i, row in enumerate(sheet.iter_rows()):
            sheet2.row_dimensions[i+1].height = sheet.row_dimensions[i+1].height
            for j, cell in enumerate(row):
                sheet2.column_dimensions[get_column_letter(j+1)].width = sheet.column_dimensions[get_column_letter(j+1)].width
                sheet2.cell(row=i + 1, column=j + 1, value=cell.value)

                # 设置单元格格式
                source_cell = sheet.cell(i+1, j+1)
                target_cell = sheet2.cell(i+1, j+1)
                target_cell.fill = copy.copy(source_cell.fill)
                if source_cell.has_style:
                    target_cell._style = copy.copy(source_cell._style)
                    target_cell.font = copy.copy(source_cell.font)
                    target_cell.border = copy.copy(source_cell.border)
                    target_cell.fill = copy.copy(source_cell.fill)
                    target_cell.number_format = copy.copy(source_cell.number_format)
                    target_cell.protection = copy.copy(source_cell.protection)
                    target_cell.alignment = copy.copy(source_cell.alignment)

其中sheetnames为你想要的sheet顺序list。

缺点:如果sheet太多或者内容量太多运行时间就会过长。