格式化 du 命令输出

Kub*_*ski 2 shell formatting zsh du

有没有办法格式化(在shell命令链中)以下输出 du -s -k *

287720  crm-cc
21500   crm-mvh
40360   elasticsearch-5.1.2
293292  electron-quick-start
44636   hexagon
193572  jpk
132 knights
209860  pink-panther
1722104 popc
4   server-config.txt
45392   sigb-backend
47468   test
58904   um-report
164156  zeus
Run Code Online (Sandbox Code Playgroud)

通过以下方式:

1,763,434,496 popc
  300,331,008 electron-quick-start
  294,625,280 crm-cc
  214,896,640 pink-panther
  198,217,728 jpk
  168,095,744 zeus
   60,317,696 um-report
   48,607,232 test
   46,481,408 sigb-backend
   45,707,264 hexagon
   41,328,640 elasticsearch-5.1.2
   22,016,000 crm-mvh
      135,168 knights
        4,096 server-config.txt
Run Code Online (Sandbox Code Playgroud)

我的意思是:

  • 按大小降序对文件/目录进行排序。
  • 从右边开始每三个字符插入一个千位分隔符。
  • 插入前导空格以将尺寸向右对齐

我已经在 PHP 中实现了这个,但我希望有一个更通用的解决方案(不是每个基于 linux 的操作系统都安装了 PHP 解释器)。

如果相关,我zsh大部分时间都在使用,因此解决方案可以仅限于此外壳。

Joh*_*024 5

例如,让我们考虑一个包含这些文件的目录:

$ du -sk *
12488   big.log
200     big.pdf
4       f1
2441412 output.txt
160660  program.zip
4       smallfile
4       some.txt
Run Code Online (Sandbox Code Playgroud)

根据需要重新格式化du

$ du -sk * | sort -rn | sed -E ':a; s/([[:digit:]]+)([[:digit:]]{3})/\1,\2/; ta' | awk -F'\t' '{printf "%10s %s\n",$1,substr($0,length($1)+2)}'
 2,441,412 output.txt
   160,660 program.zip
    12,488 big.log
       200 big.pdf
         4 some.txt
         4 smallfile
         4 f1
Run Code Online (Sandbox Code Playgroud)

注意:这种方法甚至适用于包含空格的文件名。

方便的shell函数

由于上面要输入的内容很多,让我们创建一个shell函数:

$ dusk() { du -sk "$@" | sort -rn | sed -E ':a; s/([[:digit:]]+)([[:digit:]]{3})/\1,\2/; ta' | awk -F'\t' '{printf "%10s %s\n",$1,substr($0,length($1)+2)}';}
Run Code Online (Sandbox Code Playgroud)

我们可以使用shell函数如下:

$ dusk *
 2,441,412 output.txt
   160,660 program.zip
    12,488 big.log
       200 big.pdf
         4 some.txt
         4 smallfile
         4 f1
Run Code Online (Sandbox Code Playgroud)

这个怎么运作

  • du -sk *

    这是我们的du命令。

  • sort -rn

    这以相反的顺序进行数字排序,以便最大的文件排在第一位。

  • sed -E ':a; s/([[:digit:]]+)([[:digit:]]{3})/\1,\2/; ta'

    这会将逗号放在我们想要的地方。

  • awk -F'\t' '{printf "%10s %s\n",$1,substr($0,length($1)+2)}';}

    这对数字进行了右对齐。

多行版本

对于那些喜欢将命令分散到多行的人:

du -sk * |
    sort -rn |
    sed -E ':a; s/([[:digit:]]+)([[:digit:]]{3})/\1,\2/; ta' |
    awk -F'\t' '{printf "%10s %s\n",$1,substr($0,length($1)+2)}'
Run Code Online (Sandbox Code Playgroud)

与 Mac OSX/BSD 的兼容性

试试这个,看看它是否适用于 OSX:

$ echo 1234567890 | sed -E -e :a -e 's/([[:digit:]]+)([[:digit:]]{3})/\1,\2/' -e ta 
1,234,567,890
Run Code Online (Sandbox Code Playgroud)

如果可行,那么让我们将完整命令修改为:

du -sk * | sort -rn | sed -E -e :a -e 's/([[:digit:]]+)([[:digit:]]{3})/\1,\2/' -e ta  | awk -F'\t' '{printf "%10s %s\n",$1,substr($0,length($1)+2)}'
Run Code Online (Sandbox Code Playgroud)