python合并多个excel

简介: 前言代码编写1.导包2.定义位置和表头3.获取要合并的所有exce表格4.打开Exce文件5.获取exce文件下的所有sheet6.获取sheet下有多少行数据7.获取sheet下的数据8.主函数完整代码报错修改另外最后

前言

1.工作中,经常需要合并多个Excel文件。如果文件数量比较多,则工作量大,易出错,此时,可以使用Python来快速的完成合并。

2.使用方法:将需要合并的多个Excel文件放到同一个文件夹下,程序运行后,输入文件夹目录的地址即可,完成合并后会将合并后的文件放在当前目录下。

3.可以查看代码的详细编写,或者直接到最后复制完整代码使用。


代码编写

1.导包

import os
import xlrd2
import xlsxwriter
import glob

2.定义位置和表头

biao_tou = "NULL"
wei_zhi = "NULL"

3.获取要合并的所有exce表格

def get_exce():
    global wei_zhi
    wei_zhi = input("请输入Excel文件所在的目录:")
    all_exce = glob.glob(wei_zhi + "\*.xlsx")
    print("该目录下有" + str(len(all_exce)) + "个excel文件:")
    if (len(all_exce) == 0):
        return 0
    else:
        for i in range(len(all_exce)):
            print(all_exce[i])
        return all_exce

4.打开Exce文件

def open_exce(name):
    fh = xlrd2.open_workbook(name)
    return fh

5.获取exce文件下的所有sheet

# 获取exce文件下的所有sheet
def get_sheet(fh):
    sheets = fh.sheets()
    return sheets

6.获取sheet下有多少行数据

def get_sheetrow_num(sheet):
    return sheet.nrows

7.获取sheet下的数据

def get_sheet_data(sheet, row):
    for i in range(row):
        if (i == 0):
            global biao_tou
            biao_tou = sheet.row_values(i)
            continue
        values = sheet.row_values(i)
        all_data1.append(values)
    return all_data1

8.主函数

if __name__ == '__main__':
    all_exce = get_exce()
    # 得到要合并的所有exce表格数据
    if (all_exce == 0):
        print("该目录下无.xls文件!请检查您输入的目录是否有误!")
        os.system('pause')
        exit()
    all_data1 = []
    # 用于保存合并的所有行的数据
    # 下面开始文件数据的获取
    for exce in all_exce:
        fh = open_exce(exce)
        # 打开文件
        sheets = get_sheet(fh)
        # 获取文件下的sheet数量
        for sheet in range(len(sheets)):
            row = get_sheetrow_num(sheets[sheet])
            # 获取一个sheet下的所有的数据的行数
            all_data2 = get_sheet_data(sheets[sheet], row)
            # 获取一个sheet下的所有行的数据
    all_data1.insert(0, biao_tou)
    # 表头写入
    # 下面开始文件数据的写入
    new_exce = wei_zhi + "\总数据.xlsx"
    # 新建的exce文件名字
    fh1 = xlsxwriter.Workbook(new_exce)
    # 新建一个exce表
    new_sheet = fh1.add_worksheet()
    # 新建一个sheet表
    for i in range(len(all_data1)):
        for j in range(len(all_data1[i])):
            c = all_data1[i][j]
            new_sheet.write(i, j, c)
    fh1.close()
    # 关闭该exce表
    print("文件合并成功,请查看“" + wei_zhi + "”目录下的总数据.xlsx文件!")
    os.system('pause')
    os.system('pause')

完整代码

import os
import xlrd2
import xlsxwriter
import glob
biao_tou = "NULL"
wei_zhi = "NULL"
# 获取要合并的所有exce表格
def get_exce():
    global wei_zhi
    wei_zhi = input("请输入Excel文件所在的目录:")
    all_exce = glob.glob(wei_zhi + "\*.xlsx")
    print("该目录下有" + str(len(all_exce)) + "个excel文件:")
    if (len(all_exce) == 0):
        return 0
    else:
        for i in range(len(all_exce)):
            print(all_exce[i])
        return all_exce
# 打开Exce文件
def open_exce(name):
    fh = xlrd2.open_workbook(name)
    return fh
# 获取exce文件下的所有sheet
def get_sheet(fh):
    sheets = fh.sheets()
    return sheets
# 获取sheet下有多少行数据
def get_sheetrow_num(sheet):
    return sheet.nrows
# 获取sheet下的数据
def get_sheet_data(sheet, row):
    for i in range(row):
        if (i == 0):
            global biao_tou
            biao_tou = sheet.row_values(i)
            continue
        values = sheet.row_values(i)
        all_data1.append(values)
    return all_data1
if __name__ == '__main__':
    all_exce = get_exce()
    # 得到要合并的所有exce表格数据
    if (all_exce == 0):
        print("该目录下无.xlsx文件!请检查您输入的目录是否有误!")
        os.system('pause')
        exit()
    all_data1 = []
    # 用于保存合并的所有行的数据
    # 下面开始文件数据的获取
    for exce in all_exce:
        fh = open_exce(exce)
        # 打开文件
        sheets = get_sheet(fh)
        # 获取文件下的sheet数量
        for sheet in range(len(sheets)):
            row = get_sheetrow_num(sheets[sheet])
            # 获取一个sheet下的所有的数据的行数
            all_data2 = get_sheet_data(sheets[sheet], row)
            # 获取一个sheet下的所有行的数据
    all_data1.insert(0, biao_tou)
    # 表头写入
    # 下面开始文件数据的写入
    new_exce = wei_zhi + "\总数据.xlsx"
    # 新建的exce文件名字
    fh1 = xlsxwriter.Workbook(new_exce)
    # 新建一个exce表
    new_sheet = fh1.add_worksheet()
    # 新建一个sheet表
    for i in range(len(all_data1)):
        for j in range(len(all_data1[i])):
            c = all_data1[i][j]
            new_sheet.write(i, j, c)
    fh1.close()
    # 关闭该exce表
    print("文件合并成功,请查看“" + wei_zhi + "”目录下的总数据.xlsx文件!")
    os.system('pause')
    os.system('pause')
\

报错修改

(1)Python3.9版本在利用第三方库xlrd读取.xlsx格式的Excel文件时报错:

AttributeError: ‘ElementTree‘ object has no attribute ‘getiterator‘

报错原因:在新版python3.9中,windows中使用的更新删除了getiterator方法,所以我们老版本的xlrd库调用getiterator方法时会报错。

解决方法:


17.png18.png

另外

(1)需要将.xls文件合并成.xlsx文件的

19.png


(2)需要将.xlsx文件合并成.xls文件的

20.png


并且此处合并后的文件名可以自行更改。


最后

到此这篇关于教你用Python代码实现合并excel文件的文章就介绍到这了,更多相关Python合并excel文件内容请查看博主其他的文章或继续浏览下面的相关文章希望大家以后多多支持!

相关文章
|
1月前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####
158 10
|
16天前
|
数据可视化 数据挖掘 大数据
1.1 学习Python操作Excel的必要性
学习Python操作Excel在当今数据驱动的商业环境中至关重要。Python能处理大规模数据集,突破Excel行数限制;提供丰富的库实现复杂数据分析和自动化任务,显著提高效率。掌握这项技能不仅能提升个人能力,还能为企业带来价值,减少人为错误,提高决策效率。推荐从基础语法、Excel操作库开始学习,逐步进阶到数据可视化和自动化报表系统。通过实际项目巩固知识,关注新技术,为职业发展奠定坚实基础。
|
2月前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
146 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
1月前
|
机器学习/深度学习 前端开发 数据处理
利用Python将Excel快速转换成HTML
本文介绍如何使用Python将Excel文件快速转换成HTML格式,以便在网页上展示或进行进一步的数据处理。通过pandas库,你可以轻松读取Excel文件并将其转换为HTML表格,最后保存为HTML文件。文中提供了详细的代码示例和注意事项,帮助你顺利完成这一任务。
49 0
|
3月前
|
数据处理 Python
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
这篇文章介绍了如何使用Python读取Excel文件中的数据,处理后将其保存为txt、xlsx和csv格式的文件。
224 3
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
|
3月前
|
Python
python读写操作excel日志
主要是读写操作,创建表格
74 2
|
3月前
|
IDE 开发工具 数据安全/隐私保护
Python编程--实现用户注册信息写入excel文件
Python编程--实现用户注册信息写入excel文件
30 1
|
3月前
|
索引 Python
Excel学习笔记(一):python读写excel,并完成计算平均成绩、成绩等级划分、每个同学分数大于70的次数、找最优成绩
这篇文章是关于如何使用Python读取Excel文件中的学生成绩数据,并进行计算平均成绩、成绩等级划分、统计分数大于70的次数以及找出最优成绩等操作的教程。
120 0
|
3月前
|
存储 Python
Python实战项目Excel拆分与合并——合并篇
Python实战项目Excel拆分与合并——合并篇
76 0
|
3月前
|
存储 Python 容器
Python实战项目:Excel拆分与合并
Python实战项目:Excel拆分与合并
62 0

热门文章

最新文章