如何遍历目录中的子目录并计算python中子目录中的文件

时间:2015-11-26 12:49:52

标签: python count directory subdirectory

我想迭代目录中的子目录并获取每个子目录中的文件数。我的(凌乱)解决方案看起来像这样:

import os, sys
import subprocess

def Count_files_in_subd():

    for root, dirs, files in os.walk("/Path/to/directory", topdown=False):
        for name in dirs:
            print name
            f = os.path.join(root, name)
            os.chdir(f)
            i=0
            for filename in os.listdir(os.getcwd()):
                i+=1
            print i


Count_files_in_subd()

该脚本首先一个接一个地查看目录中的子目录,而不是更改它“查看”的目录,以计算其中的文件。

它有效,但我知道在python中有更好的方法可以做到这一点。我在SO上查看了不同的问题,但是当我尝试大多数解决方案时,每个子目录的文件数量只有一个,我假设该目录被计为文件。任何有关如何做到这一点的帮助将不胜感激。

2 个答案:

答案 0 :(得分:1)

您可以按如下方式重新编码,以显示每个文件夹中的文件数:

import os

def Count_files_in_subd():
    for root, dirs, files in os.walk("/Path/to/directory"):
        print "{} in {}".format(len(files), root)

Count_files_in_subd()

root保留当前正在处理的文件夹,并且files已经包含该文件夹中的所有文件,因此您只需要计算它们len(files)

dirs保存当前文件夹中的所有文件夹(将在下一个访问)。如果您不想访问某个文件夹,可以从此列表中删除它们。

这会给你以下类型的输出:

5 in /Path/to/directory
10 in /Path/to/directory/folder_1
3 in /Path/to/directory/folder_1/deeper

答案 1 :(得分:0)

你可以在bash中执行此操作,它不是很干净,但使用递归列表,您可以确保遍历每个目录。

ls -lR|while read i ; do J=$(echo $i|awk '{print $1}'|grep d|wc -l); echo     $J; if [ $J -gt 0 ]; then echo "GREATER"; fi done