批量获取文件夹以及子文件夹下文件数量,输出到Excel表格?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了批量获取文件夹以及子文件夹下文件数量,输出到Excel表格?相关的知识,希望对你有一定的参考价值。

如果你有点DOS命令的基础,我下面说的你就能看懂了。

按WIN+R打开运行,输入CMD,按回车,打开DOS窗口

进入你需要统计文件数量的那个目录,如果你不会DOS命令的话,就把文件夹复制到一个盘符根目录下,假设在D盘根目录下,文件夹名"123"

在DOS中依次输入

d:

按回车

cd 123

按回车

这时你就进入这个目录了

dir /s > 1.txt

回车之后,会在这个目录里形成一个1.txt的文件,文件中包含了你目录及子目录的文件信息

回到资源管理器里打开这个文件,里面就是你想要的东西。

追问

谢谢,由于是项目经理安排的,项目经理的意思是不要这些明细,只要文件夹名称和对应的数量

就是在思考这个问题

参考技术A

直接用excel自带的power query查询即可:

【数据】-【获取数据】-【来自文件】-【从文件夹】,选择文件夹,打开】,【加载】,搞定:该文件夹及其子文件夹下的文件列表就加载到excel中了,有文件名、文件类型、文件的时间信息、路径信息等;下来随意你,可以进行分类筛选、统计都可以了。

如果你的excel版本没有包含这个插件工具,自己上网下载power query这个插件安装吧。

参考技术B VBA可以实现的。先找path,然后dir读文件,进入文件夹在记一下数追问

能详细讲解一下嘛,谢谢

Python - 批量获取文件夹的大小输出为文件格式化保存

很多时候,查看一个文件夹下的每个文件大小可以轻易的做到,因为文件后面就是文件尺寸,但是如果需要查看一个文件夹下面所有的文件夹对应的尺寸,就发现需要把鼠标放到对应的文件夹上,稍等片刻才会出结果。

有时候,我们需要查看几十个甚至于上百个文件夹,找出包含文件最多,空间占用最大的那个,就比较麻烦了。这段代码是我以前的代码,可以按大小排序输出文件夹大小到txt文件,供使用的方便。

格式化当时花了很长时间,最后发现使用‘YaHei.Consolas’字体可以解决,对齐后输出结果看起来还算舒服。

上代码:

import os
import datetime


def get_folder_size(path):
    folder_size = 0

    if not os.path.exists(path):
        return folder_size

    if os.path.isfile(path):
        folder_size = os.path.getsize(path)
        return folder_size
    try:
        if os.path.isdir(path):
            with os.scandir(path) as directory_lists:
                for directory_list in directory_lists:
                    if directory_list.is_dir():
                        sub_folder_size = get_folder_size(directory_list.path)  # 递归获取大小
                        folder_size += sub_folder_size
                    elif directory_list.is_file():
                        file_size = os.path.getsize(directory_list.path)
                        folder_size += file_size

                return folder_size
    except:
        pass


# 以下主要是为了格式化输出
def get_file_length(file_name):
    characters = list(file_name)
    ascii_length = 0
    utf8_length = 0

    for character in characters:
        if ord(character) < 128:
            ascii_length += 1
        else:
            utf8_length += 2

    return ascii_length + utf8_length


def main(basedir):
    with os.scandir(basedir) as dirs:
        directory_size = []
        for dir in dirs:
            try:
                if not dir.is_file():
                    dirsize = round(get_folder_size(dir.path) / 1000000)  # return the file size in Mb
                    resformat = [dir.name, dirsize]
                    directory_size.append(resformat)
            except:
                pass
        results = sorted(directory_size, key=lambda x: x[1], reverse=True)  # return a list ordered by size
        results = [[i[0], \'文件夹大小:\' + str(i[1]) + \' Mb\'] for i in results]

        with open(basedir + os.sep + datetime.date.today().isoformat() + \'.txt\', \'a+\') as f:
            for result in results:
                # 按照50的宽度格式化输出结果
                len1 = 50 - get_file_length(result[0]) + len(result[0])
                len2 = 25 - get_file_length(result[1]) + len(result[1])
                f.writelines(\'{:<{len1}s} {:>{len2}s}\\n\'.format(result[0], result[1], len1=len1, len2=len2))
            print(\'The result was successfully saved in the directory with date as file name.\')


if __name__ == "__main__":
    basedir = input("Please input the directory you would like to know the sizes: ")
    main(basedir)


如果输入相应的文件夹路径,输出结果如下:


20200329114718

20200329114723

有时间我再简化一下代码,目前先这样。

以上是关于批量获取文件夹以及子文件夹下文件数量,输出到Excel表格?的主要内容,如果未能解决你的问题,请参考以下文章

C#如何遍历指定目录以及指定目录下所有子文件夹,并获取除指定文件类型以外的所有文件的绝对路径?

如何快速将子文件夹下的文件全部复制到一个总的根目录下

PDF文件数量过多的情况下如何批量转换成word文档?

PHP如何获取文件夹下所以子文件夹的名称及子夹所以图片

Excel怎样批量提取文件夹和子文件夹所有文件?

Java一键批量替换掉文件夹以及子文件的名称