微信号:Python_xiaowu

介绍:清华出版社《Python程序设计》系列教材作者董付国的Python小屋.介绍Python基础语法知识、标准库、扩展库知识,探讨Python在各领域的应用.

Python合并Excel2007+中多个WorkSheet

2016-07-23 07:22 李昕,董付国

感谢中国石油大学(华东)计算机与通信工程学院李昕老师提供的问题和第一版代码,并和我一起反复修改和完善得到了最终版本的代码。

import os

import sys

from tkinter import Tk, Button

from tkinter import filedialog

from tkinter import simpledialog


try:

    import openpyxl

except:

    #先把pip升级到最新版本

    path = '"'+os.path.dirname(sys.executable)+'\\scripts\\pip" install --upgrade pip'

    os.system(path)

    #安装openpyxl扩展库

    path = '"'+os.path.dirname(sys.executable)+'\\scripts\\pip" install openpyxl'

    os.system(path)

    import openpyxl


def merge(start):

    #显示打开文件对话框,打开要合并的Excel 2007+文件

    opts= {'filetypes':[('Excel 2007', '.xlsx')]}

    filename = filedialog.askopenfilename(**opts)

    #如果没有选择文件,不再执行后面的代码

    if not filename:

        return

    #分割路径和文件名

    filepath, tempfilename = os.path.split(filename)

    shotname = os.path.splitext(tempfilename)[0]

    #生成的新文件名

    newFile = filepath + '\\' + shotname + '_merge.xlsx'

    #创建新的Excel 2007+文件

    workbook = openpyxl.Workbook()

    #添加新的worksheet

    worksheet = workbook.worksheets[0]

    data = openpyxl.load_workbook(filename)

    for sheetnum, sheet in enumerate(data.worksheets):

        #根据设定的表头行数,设置读取的起始行

        #第一个sheet读取表头,后面的sheet忽略表头

        if sheetnum == 0:

            rowStart = 0

        else:

            rowStart = start

        #遍历原sheet,根据情况忽略表头

        for row in sheet.rows[rowStart:]:

            line = [col.value for col in row]

            worksheet.append(line)

    #保存新文件

    workbook.save(newFile)

    #打开刚刚创建的新文件

    os.startfile(newFile)

    

#单击按钮后执行的函数,参数a表示Excel文件中每个worksheet预期表头行数

def callback():

    kw = {'initialvalue':1, 'minvalue':0, 'maxvalue':10}

    headerNum = simpledialog.askinteger('表头行数', '请输入表头行数',**kw)

    if headerNum != None:

        merge(headerNum)

    

root = Tk()

root.title("合并sheet")

Button(root, text="合并WorkSheets", bg='blue', bd=2,width=28,command=callback).pack()


root.mainloop()


 
Python小屋 更多文章 《Python程序设计》系列教材 使用Python列表实现向量运算 Python监视进程创建情况和系统服务状态 Python+shelve读写二进制文件 Python实时获取鼠标下窗口文本
猜您喜欢 分析Proactor前摄器模式与操作系统异步IO 大家来“找茬”第二季 ||参与用户评测,赢取IT神书 Android单元测试(四):Mock以及Mockito的使用 一个IT人士的个人经历,给迷失方向的朋友 详解|一文带你暴力拆解大数据