python实现自动化之文件合并

 更新时间:2021年08月12日 10:28:31   作者:Alan.hsiang  
这篇文章主要为大家详细介绍了python实现自动化文件合并,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

假如公司需要统计每个员工的个人信息,制定好模板后,由员工填写,然后发送到综合部进行汇总,在这种情况下,如果公司有上百位员工的信息需要统计,且采用纯手工进行复制粘贴的方式进行汇总,则将是一项耗时费力易错的工作。本文主要以一个简单的小例子,简述如何通过Pyhton进行自动化文件合并。

涉及知识点

  • xlrd模块:文件的读取
  • xlwt模块:文件的生成

设计思路

1、获取指定目录下所有excel格式的文件。
2、循环读取Excel文件内容【读取固定的行与列】,将内容暂存内存中。
3、将内存中数据,写入到新的Excel文件中,并保存到指定位置。

效果示例

本例为了简化操作,总共有10个需要汇总的文件,如下所示:

每一个文件采用相同模板,格式一致,如下所示:

汇总后的文件,如下所示:

核心代码

引入相关的模块,如下所示:

import xlrd
import xlwt
import os

读取excel内容,如下所示:

def read_excel(excel_folder: str):
    """
    读取Excel文档
    :param excel_folder:
    :return:
    """
    excel_files = []  # excel文件列表
    excel_contents = []  # excel文件内容
    files = os.listdir(path=excel_folder)
    if len(files) > 0:
        for file in files:
            if file.endswith('.xls'):
                excel_files.append(file)
    if len(excel_files) == 0:
        print('此目录下没有对应的Excel文件')
    # 循环读取文档
    for file in excel_files:
        full_path = os.path.join(excel_folder, file)
        book = xlrd.open_workbook(filename=full_path)
        sheet = book.sheet_by_index(sheetx=0)
        # 取固定位置的值
        content = {
            '名称': sheet.cell_value(1, 0),
            '年纪': sheet.cell_value(1, 1),
            '性别': sheet.cell_value(1, 2),
            '籍贯': sheet.cell_value(1, 3)
        }
        excel_contents.append(content)
 
return excel_contents

生成Excel内容,如下所示:

def write_excel(excel_path: str, excel_contents: list):
    """
    生成Excel文档
    :param excel_path:
    :return:
    """
    if len(excel_contents) == 0:
        print('没有需要保存的内容')
        return
    book = xlwt.Workbook(encoding='utf-8')
    sheet1 = book.add_sheet('统计信息')
    # 先写标题
    sheet1.write(0, 0, '名称')
    sheet1.write(0, 1, '年纪')
    sheet1.write(0, 2, '性别')
    sheet1.write(0, 3, '籍贯')
    i = 1
    for content in excel_contents:
        sheet1.write(i, 0, content['名称'])
        sheet1.write(i, 1, content['年纪'])
        sheet1.write(i, 2, content['性别'])
        sheet1.write(i, 3, content['籍贯'])
        i += 1
    book.save(excel_path)

整体调用

excel_folder = r'D:\MyProject\Demo01\TESTEXCEL'
excel_path = r'D:\MyProject\Demo01\TESTEXCEL\汇总信息.xls'
excel_contents = read_excel(excel_folder)
# print(excel_contents)
write_excel(excel_path, excel_contents)
print('done')

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • python+OpenCV实现车牌号码识别

    python+OpenCV实现车牌号码识别

    这篇文章主要介绍了python+OpenCV实现车牌号码识别,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • python正则表达式的懒惰匹配和贪婪匹配说明

    python正则表达式的懒惰匹配和贪婪匹配说明

    这篇文章主要介绍了python正则表达式的懒惰匹配和贪婪匹配说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • Python生成任意范围任意精度的随机数方法

    Python生成任意范围任意精度的随机数方法

    下面小编就为大家分享一篇Python生成任意范围任意精度的随机数方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-04-04
  • keras 如何保存最佳的训练模型

    keras 如何保存最佳的训练模型

    这篇文章主要介绍了keras 如何保存最佳的训练模型,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-05-05
  • Python3.6中Twisted模块安装的问题与解决

    Python3.6中Twisted模块安装的问题与解决

    这篇文章主要介绍了Python3.6中Twisted模块安装的问题与解决,文中通过示例代码介绍的非常详细,对大家学习或者使用Python具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-04-04
  • 详解python中的变量与注释

    详解python中的变量与注释

    在 Python 中,变量是用于存储数据的名称,它可以保存不同类型的数据,在Python中,有两种类型的注释:单行注释和多行注释,本文就给大家详细的介绍一下python中的变量与注释,需要的朋友可以参考下
    2023-08-08
  • 解决Python 中JSONDecodeError: Expecting value: line 1 column 1 (char 0)错误

    解决Python 中JSONDecodeError: Expecting value:&n

    这篇文章主要介绍了解决Python 中JSONDecodeError: Expecting value: line 1 column 1 (char 0)错误问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • Python利用PIL实现多张图片合成gif动画的案例详解

    Python利用PIL实现多张图片合成gif动画的案例详解

    这篇文章主要介绍了Python利用PIL实现多张图片合成gif动画的案例,文章通过代码示例介绍的非常详细,对大家的学习或工作有一定的帮助,感兴趣的小伙伴可以自己动手试一下
    2023-11-11
  • Python json转字典字符方法实例解析

    Python json转字典字符方法实例解析

    这篇文章主要介绍了Python json转字典字符代码实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • Python使用Selenium WebDriver的入门介绍及安装教程(最新推荐)

    Python使用Selenium WebDriver的入门介绍及安装教程(最新推荐)

    这篇文章主要介绍了Python使用Selenium WebDriver的入门介绍及安装教程,本文使用环境为python3.11+win10 64位+firefox浏览器,所以本文使用的浏览器驱动是Firefox的geckodriver ,如果你使用的是其他浏览器,那么选择自己对应的浏览器驱动程序即可,需要的朋友可以参考下
    2023-04-04

最新评论