我想迭代目录中的子目录并获取每个子目录中的文件数。我的(凌乱)解决方案看起来像这样:
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上查看了不同的问题,但是当我尝试大多数解决方案时,每个子目录的文件数量只有一个,我假设该目录被计为文件。任何有关如何做到这一点的帮助将不胜感激。
答案 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