用Python高效地将 多个excel表快速汇总成一个excel表–python办公实用小技能分享

时间:2020-8-30 作者:admin


  相信很多友友们都遇到一个同样的问题,就是将多个excel表汇总成一个表效率极低,不止如此,还要看有没有复制错。在学校担任多种职务的我总是要汇总很多个表格,早就用python来想解决这个问题,经过借鉴网上的多位大咖的代码,已经成功解决,接下来我将分享给大家!用Python高效地将 多个excel表快速汇总成一个excel表--python办公实用小技能分享

入正题

例如要汇总以下表格
用Python高效地将 多个excel表快速汇总成一个excel表--python办公实用小技能分享
注意:三个excel都是一样的(因为我实在编不出来数据了…)
用Python高效地将 多个excel表快速汇总成一个excel表--python办公实用小技能分享
上代码之前,我想到大家可能没有安装这些第三方模块,可以输入代码安装

pip install --user -i https://pypi.tuna.tsinghua.edu.cn/simple/ 你缺啥这里填啥

上代码

import xlrd
import xlwt
import os
from xlutils.copy import copy
import os.path
from xlwt import *

dir = input("输入文件路径\n");
start_row = input("输入需要读取起始行号\n");
start_row = int(start_row)
end_row = input("输入结束行,输入0表示有内容的最后一行\n")
end_row = int(end_row)
# dir = 'E:\毕业资料\2013电2\\'
all_file = [];


def min_s(a, b):
    if a == 0:
        return b
    if (a > b):
        return b
    else:
        return a


# 遍历所有同学文件
for parent, folder, filename in os.walk(dir):
    for file, x in zip(filename, range(len(filename))):
        file = os.path.join(parent, filename[x])
        print(filename[x])
        all_file.append(file)
print("\n文件总数:", len(all_file))
if os.path.exists("result.xls"):
    os.remove("result.xls")
w = xlwt.Workbook()
row = 0;
ws = w.add_sheet('sheet1', cell_overwrite_ok=True)
style = XFStyle()
fnt = Font()
fnt.height = 240
fnt.name = u'宋体'
style.font = fnt
align = Alignment()
align.horz = 2
style.alignment = align
for single_file_path in all_file:
    data = xlrd.open_workbook(single_file_path);
    sheet = data.sheet_by_index(0)
    if sheet.nrows >= start_row:
        for i in range(start_row - 1, min_s(end_row, sheet.nrows)):
            list = sheet.row_values(i)
            for col in range(0, len(list)):
                ws.write(row, col, list[col], style)
            row = row + 1;
    else:
        print("非法填写的表格名称:" + single_file_path)

print("运行结束,结果保存在result.xls文件里\n")
print("对于日期,可将对应单元格设置为为日期格式便可正确显示\n"
      "对于超长数字例如身份证号码,设置为文本格式即可\n")
w.save('result.xls')
os.system("pause")

代码引用:https://blog.csdn.net/xuyd33/article/details/72629460?
我自己也写了一段代码,和上面这位仁兄写的简直不能比,本以为自己写的挺不错了,没想到一比,自己的简直像一坨shit
用Python高效地将 多个excel表快速汇总成一个excel表--python办公实用小技能分享

运行结果

用Python高效地将 多个excel表快速汇总成一个excel表--python办公实用小技能分享
你此时可以在当前python文件的目录下找到这个result.xls
用Python高效地将 多个excel表快速汇总成一个excel表--python办公实用小技能分享

也可以另存为你要保存的路径

打开汇总的表格
用Python高效地将 多个excel表快速汇总成一个excel表--python办公实用小技能分享
如果有不懂的可以留言,我看到了马上回,希望可以帮到你熬!

声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。