我有一个包含大量子目录的目录。每个子目录的名称类似于“treedir_xxx”,其中 xxx 是一个数字。我想运行一个命令(最好从命令行,因为我没有使用批处理脚本的经验),该命令将计算每个名为“treedir_xxx”的子目录中的文件数量,并将这些数字写入文本文件。我觉得这应该不是很困难,但到目前为止我还没有成功。
我尝试过诸如 find *treedir* -maxdepth 1 -type f | wc -l <
但是,这仅返回文件总数,而不是每个单独文件夹中的文件数。
最佳答案
不要使用 find
,而是使用 for
循环。我假设您正在使用 bash 或类似的 shell,因为这是大多数现代 Linux 发行版上最常见的 shell:
for i in treedir_*; do ls "$i" | wc -l; done
鉴于以下结构:
treedir_001
|__ a
|__ b
|__ c
treedir_002
|__ d
|__ e
treedir_003
|__ f
结果是:
3
2
1
您可以随心所欲地在数字周围打印任何您想要的内容:
for i in treedir_*; do echo $i: $(ls "$i" | wc -l); done
给出
treedir_001: 3
treedir_002: 2
treedir_003: 1
这使用 $(...)
将命令的输出作为字符串获取,并将其传递给 echo
,然后 echo 可以在一行上打印所有内容。
for i in treedir_*; do echo $i; ls "$i" | wc -l; done
给出
treedir_001
3
treedir_002
2
treedir_003
1
此示例说明了在单个循环中使用多个命令。
for
可以像任何其他命令一样重定向到文件或通过管道传输,因此您可以执行以下操作
for i in treedir_*; do ls "$i" | wc -l; done > list.txt
或者更好
for i in treedir_*; do ls "$i" | wc -l; done | tee list.txt
第二个版本将输出发送到程序tee
,该程序将其打印到标准输出并将其重定向到文件。有时,这比使用 >
进行简单重定向更适合调试。
find
是一把强大的锤子,但并非所有东西都是钉子...
关于linux - 从命令行计算多个子目录中的文件数量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38850834/