0

我使用这个命令:

du -h --max-depth=1 | sort -s

我的结果是:

1.1M    ./abcd
1.1M    ./efgh
1.1M    ./xyxabcd
1.2G    ./oleoleole
1.2M    ./tests
196K    ./super-Package
2.0M    ./myjobs-build

但是,我希望它按大小排序,如下所示:

1.2G    ./oleoleole
2.0M    ./myjobs-build
1.2M    ./tests
1.1M    ./abcd
1.1M    ./efgh
1.1M    ./xyxabcd
196K    ./super-Package
4

4 回答 4

2
du -sh * | sort -hr

这里 -h 标志告诉操作系统排序输入是人类可读的格式

这里 -r 标志告诉按降序排序

样本输出:

Sai Kiran@Windows MINGW32 /bin
$ du -sh * | sort -hr
3.5M    msys-2.0.dll
2.3M    vimdiff.exe
2.3M    vim.exe
2.3M    view.exe
2.3M    rvim.exe
2.3M    rview.exe
2.3M    ex.exe
2.1M    sh.exe
2.1M    bash.exe
2.0M    msys-crypto-1.0.0.dll
1.9M    msys-perl5_22.dll
1.1M    sed.exe
932K    gpg.exe
928K    msys-svn_subr-1-0.dll
912K    msys-iconv-2.dll
816K    msys-sqlite3-0.dll
760K    winpty-agent.exe
756K    sshd.exe
712K    winpty.dll
704K    msys-svn_wc-1-0.dll
700K    ssh.exe
700K    slogin.exe
628K    rebase.exe
588K    openssl.exe
568K    gawk-4.1.3.exe
568K    gawk.exe
568K    awk.exe
557K    core_perl
544K    msys-asn1-8.dll
508K    msys-gmp-10.dll
472K    winpty.exe
472K    msys-curl-4.dll
452K    msys-krb5-26.dll
432K    ssh-keyscan.exe
432K    cygcheck.exe
428K    msys-svn_client-1-0.dll
于 2016-05-17T10:03:45.803 回答
1

你可以试试du -h --max-depth=1 | sort -hr

于 2016-05-17T12:04:01.110 回答
0

只需du以字节为单位打印,对数据进行排序和后处理awk

du --max-depth=1 |
   sort -n -k1 | 
   awk -v u="K M G T" 'BEGIN{split(u, units);}
   { while($1 > 1024) {$1/=1024; unit++} $1=$1 FS units[unit]; unit=0 }
   1'

测试

$ mkdir a{1..3}
$ seq 100000 > a1/a
$ seq 100000000 > a2/a
$ seq 100 > a3/a

所以我们有:

$ du -h --max-depth=1
580K    ./a1
8,0K    ./a3
848M    ./a2
849M    .

现在我们看到:

$ du --max-depth=1 | sort -n -k1 | awk -v u="K M G T" 'BEGIN{split(u, units);} { while($1 > 1024) {$1/=1024; unit++} $1=$1 units[unit]; unit=0 }1'
8 ./a3
580 ./a1
847.719K ./a2
848.297K .
于 2016-05-17T10:08:16.163 回答
0

sort命令只会按照其手册页中的说明对输出文件的行进行排序:

sort - 对文本文件的行进行排序

当您想按大小对文件进行排序时,您可以简单地使用ls-S开关的命令:

-s, --size 打印每个文件的分配大小,以块为单位

-S 按文件大小排序,最大的在前

关联

于 2016-05-17T10:10:31.420 回答