druid_yy 2023-01-07 23:39 采纳率: 11.1%
浏览 41
已结题

想写一个能获得文件夹内所有文件名字,并写入Excel的脚本

path=r"D:\各种模\选股结果"
os.listdir(path)
['ipynb_checkpoint','module.ipynb','文件夹1','文件夹2','表格2.xlsx']

img

  • 写回答

5条回答 默认 最新

  • starlight_2007 2023-01-08 00:47
    关注

    我们也可以对os.listdir()函数的结果进行筛选,将目录排除在外,只保留文件名。

    from openpyxl import Workbook
    import os
    
    #定义函数:功能为获取到的文件列表写入excel文件。
    #接收文件列表作为参数,并根据使用的操作系统决定存储路径(虽然一般没有必要,但是在指定路径下的存储需要使用此功能)
    def write_in(obj_lst, path = os.getcwd(), plat = os.sys.platform):
        wb = Workbook()#新建工作簿
        sht = wb.active#激活工作表
        for i in range(len(obj_lst)):
            sht[f'A{i+1}'] = obj_lst[i]#将文件名依次存储在最左边一列中
        if plat == 'darwin':#判断系统
            save_path = f'{path}/ReadMe.xlsx'
        else:
            save_path = f'{path}\\ReadMe.xlsx'
        wb.save(save_path)#保存文件
        print(f'已完成写入。\nexcel文件路径为{save_path}')#提示完成进度和文件保存位置
        return save_path
    
    #定义函数:获取指定目录下的所有文件名
    def get_obj(path):
        names = os.listdir(path)
        files = []
        for i in names:
            if '.' in i:
                files.append(i)
        return files
    
    #定义函数:与用户交互
    def inter():
        path = input('请输入要检索的目录的绝对路径\n>>[')
        write_in(get_obj(path))
    
    #调用函数
    if __name__ == '__main__':
        inter()
    

    如果您所说的“文件”也包含目录(即文件夹)的话,请使用如下代码:

    from openpyxl import Workbook
    import os
    def write_in(path, obj_lst, plat):
        wb = Workbook()
        sht = wb.active
        for i in range(len(obj_lst)):
            sht[f'A{i+1}'] = obj_lst[i]
        if plat == 'darwin':
            save_path = f'{path}/ReadMe.xlsx'
        else:
            save_path = f'{path}\\ReadMe.xlsx'
        wb.save(save_path)
        print(f'已完成写入。\nexcel文件路径为{save_path}')
        return save_path
    def get_obj(path):
        names = os.listdir(path)
        files = []
        for i in names:
            files.append(i)
        return files
    def inter():
        path = input('请输入要检索的目录的绝对路径\n>>[')
        write_in(os.getcwd(), get_obj(path), os.sys.platform)
    inter()
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
    1人已打赏
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 1月16日
  • 已采纳回答 1月8日
  • 创建了问题 1月7日

悬赏问题

  • ¥17 pro*C预编译“闪回查询”报错SCN不能识别
  • ¥15 微信会员卡接入微信支付商户号收款
  • ¥15 如何获取烟草零售终端数据
  • ¥15 数学建模招标中位数问题
  • ¥15 phython路径名过长报错 不知道什么问题
  • ¥15 深度学习中模型转换该怎么实现
  • ¥15 Stata外部命令安装问题求帮助!
  • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
  • ¥15 如何用python向钉钉机器人发送可以放大的图片?
  • ¥15 matlab(相关搜索:紧聚焦)