sort 是 Linux 的排序命令,但是可以依据不同的数据类型来进行排序。sort 将文档的每一行成为一个单位,互相比较。比较原则是从首字符向后,依次按 ASCII 码值进行比较,最终将这些按升序输出。
sort 命令格式如下:
[root@localhost ~]# sort [选项] 文件名
选项:
sort 命令默认是用每行结尾的第一个字符来进行排序的,譬如:
[root@localhost ~]# sort /etc/passwd
#排序文档
abrt:x:173:173::/etc/abrt:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin apache:x:48:48:Apache:/var/www:/sbin/nologin
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
…省略部分输出…
因为想要反向排序,则使用“-r”选项sort 排序,譬如:
[root@localhost ~]# sort -r /etc/passwd
#反向排序
vcsa:x:69:69:virtual console memory owner:/dev:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
tcpdump:x:72:72::/:/sbin/nologin
…省略部分输出…
因为想要指定排序的函数,则需要使用"-t"选项指定分隔符,并使用"-k"选项指定函数号。假如我想要根据 UID 字段排序 /etc/passwd 文件,命令如下:
[root@localhost ~]# sort -t":"-k 3,3 /etc/passwd
#指定分隔符是":",以第三个字段开头,以第三个字段结尾排序,也就是只用第三个字段排序
root:x:::root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
operator:x:11::operator:/root:/sbin/nologin
abrt:x:173:173::/etc/abrt:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
…省略部分输出…
看起来好像很美,但是因为仔细瞧瞧,什么 daemon 用户的 UID 是 2,反而排在了上面?这是因为 sort 默认是根据字符排序的,后面用户的 UID 的第一个字符都是 1,但是这样排序。要想根据数字排序,请使用"-n"选项,譬如:
[root@localhost ~]# sort -n -t":" -k 3,3 /etc/passwd
root:x:::root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spod/lpd:/sbin/nologin
...省略部分输出...
其实,"-k"选项可以直接使用"-k 3",代表从第三个字段到行尾都排序(第一个字段先排序,所以一致,则第二个字段再排序sort 排序,直到行尾)。
本文来自电脑杂谈,转载请注明本文网址:
http://www.pc-fly.com/a/jisuanjixue/article-118516-1.html