分享

Python自动化办公对每个子文件夹的Excel表加个表头(Excel不同名)(下篇)

 Python进阶者 2023-05-23 发布于广东
昭阳殿里恩爱绝,蓬莱宫中日月长。

大家好,我是皮皮。

一、前言

上一篇文章,我们抛出了一个问题,这篇文章来进行解答。如果针对子文件夹下不同的Excel表名,应该如何处理?要求一步到位。

二、实现过程

我们继续问ChatGPT,它给出了一个方法,如下所示:

提问如下:假如你是一名Python程序员,现在你有一个自动化办公的需求,你桌面上有一个新建文件夹,该文件夹下的每一个子文件夹里面都有不同名字的Excel表,但是这些Excel表只有两列,第一列是经度,第二列是纬度,现在要对每个Excel表加个表头,分别命名为经度,纬度,应该怎么写代码。

可以使用Python的pandas模块来读取Excel表格,并添加表头。具体步骤如下:

首先,需要导入os模块和pandas模块:

import os
import pandas as pd

然后,可以使用os模块的listdir()函数获取文件夹下的所有子文件夹,再遍历每个子文件夹,读取其中所有的Excel表格,对每个表格添加表头并保存。具体代码如下:

import os
import pandas as pd

# 定义文件夹路径
folder_path = r"文件夹路径"

# 获取所有子文件夹路径
subfolders = [f.path for f in os.scandir(folder_path) if f.is_dir()]

# 为每个Excel表格添加表头并保存
for subfolder in subfolders:
    # 获取该子文件夹中所有Excel表格的路径
    excel_paths = [f.path for f in os.scandir(subfolder) if f.is_file() and f.name.endswith(".xlsx")]
    for excel_path in excel_paths:
        # 读取Excel表格
        df = pd.read_excel(excel_path, header=None)
        # 添加表头
        df.columns = ['经度''纬度']
        # 保存Excel表格
        df.to_excel(excel_path, index=False)

在上述代码中,首先定义了文件夹路径。然后使用os.scandir()函数获取该文件夹下的所有子文件夹路径。接下来,遍历每个子文件夹,使用os.scandir()函数获取该子文件夹中所有Excel表格的路径,然后使用pandas模块的read_excel()函数读取Excel表格。接着,为Excel表格添加表头,使用to_excel()函数保存Excel表格。最终,每个Excel表格都会被添加表头并保存。

希望这个代码可以满足您的需求!

这样的话,就直接一步到位了,顺利地解决了粉丝的问题。

有没有同学会提出这样的疑问?如果子文件夹下还有.xls文件,那么应该怎么修改代码呢?下一篇文章,我们一起看看。

三、总结

大家好,我是皮皮。这篇文章主要盘点了一个Python自动化办公处理的问题,文中针对该问题,给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。

最后感谢粉丝【彩】提问,感谢【ChatGPT】给出的思路和代码解析,感谢【冫马讠成】等人参与学习交流。

【提问补充】温馨提示,大家在群里提问的时候。可以注意下面几点:如果涉及到大文件数据,可以数据脱敏后,发点demo数据来(小文件的意思),然后贴点代码(可以复制的那种),记得发报错截图(截全)。代码不多的话,直接发代码文字即可,代码超过50行这样的话,发个.py文件就行。


------------------- End -------------------

    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多