给定files.txt中的文件列表,我可以得到它们的大小列表,如下所示:

cat files.txt | xargs ls -l | cut -c 23-30

这会产生这样的结果:

  151552
  319488
 1536000
  225280

我怎样才能得到所有这些数字的总数呢?


当前回答

纯bash

total=0; for i in $(cat files.txt | xargs ls -l | cut -c 23-30); do 
total=$(( $total + $i )); done; echo $total

其他回答

这里是

cat files.txt | xargs ls -l | cut -c 23-30 | 
  awk '{total = total + $1}END{print total}'

这里是我的

cat files.txt | xargs ls -l | cut -c 23-30 | sed -e :a -e '$!N;s/\n/+/;ta' | bc
... |xargs|tr \  +|bc
... |paste -sd+ -|bc

第一个命令只是多了一个符号(注意,它必须在反斜杠后面有两个空格!),但它处理列中有空行的情况,而第二个命令导致带有额外加号的无效表达式。

例如:

echo "2
3
5

" | paste -sd+ -

结果

2+3+5++

哪个BC不能处理,而

echo "2
3
5

" | xargs | tr \  +

给出一个有效表达式

 2+3+5 

哪些可以被导入BC以获得最终结果

而不是使用cut从ls -l的输出中获取文件大小,你可以直接使用:

$ cat files.txt | xargs ls -l | awk '{total += $5} END {print "Total:", total, "bytes"}'

Awk将“$5”解释为第五列。这是ls -l中的列,它提供了文件大小。

我发现自己会用jq来做这样的事情,即使不使用JSON:

$ echo -e '1\n2\n3' | jq --slurp add
6

它已经成为我最近编写的几乎每个脚本的标准依赖项。