gpt4 book ai didi

linux - 计算每个文件夹的平均文件数

转载 作者:塔克拉玛干 更新时间:2023-11-03 02:07:32 25 4
gpt4 key购买 nike

所以我正在编写一个 shell 脚本来计算用户选择的文件夹中的平均文件数量

我只是不太确定,如何实现这一目标。

首先,我们要设置用户文件夹选择

#!/bin/sh
# Script for folder info
#-------------------------------------------
WANTEDFOLDER=$PWD
cd
cd $1 #Go into the folder (first argument)
$WANTEDFOLDER/folderinfo.sh
# ------------------------------------------
echo "Selected directory: $PWD"

我添加了更多类似方式的命令,但这些命令正在运行,因此为了便于阅读,我不会在此处添加它们。

所以我想知道,我怎么可能计算位于指定目录的文件夹内的平均文件数。

为了更好地理解这一点,让我们设置一个示例目录

$ mkdir testdir
$ cd testdir
$ mkdir 1
$ mkdir 2
$ mkdir 3
$ cd 1
$ echo "hello" > wow.txt
$ cd ..
$ cd 2
$ echo "World"; > file.c
$ echo "file number 2" > twoinone.tex
$ cd ..
$ cd 3
$ echo "zzz" > z.txt
$ echo "zz2" > z2.txt
$ echo "zz3" ? z3.txt

好吧,在这之后为了更好地说明,文件夹看起来像这样

首先,我们将执行 find 。 -类型 f

这应该打印以下结果

./1/wow.txt
./2/file.c
./2/twoinone.tex
./3/z.txt
./3/z2.txt
./3/z3.txt

现在目录 1 中有 1 个文件,目录 2 中有 2 个文件,目录 3 中有 3 个文件。所以计算平均值是 (1 + 2 + 3)/3 结果是 2。

这也可以写成一个算法

(所有唯一文件的数量)/(所有唯一目录的数量)

一件事是在头脑中计算,另一件事是在实际的 shell 脚本中计算。

所以换句话说,我需要以某种方式转换成脚本,它会计算特定文件夹中的文件数量,存储它,将所有文件一起计算,然后最后将它除以唯一文件的数量目录。

因此,要获得目录的数量,我们必须执行 find 。 -类型d | wc -l

获取文件数量,很简单。我们将只使用 find 。 -类型f | wc -l

但我不知道的是,我怎样才能将这两个值存储在一个变量中,然后将它们相除

此外,理想情况下,我更喜欢以特定行的方式格式化代码

例如。 echo "Average Number of files: $(find . -type f | wc -l (somehow divide) find . -type d | wc -l)"

知道如何实现这一壮举吗?

最佳答案

也许这就是您正在寻找的:

echo $(( $(find . -type f | wc -l) / $(find . -type d | wc -l) ))

关于linux - 计算每个文件夹的平均文件数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36265382/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com