sort命令:字符串排序

sort 命令可以依据不同的数据类型来进行排序。sort 将文件的每一行作为一个单位,相互比较。比较原则是从首字符向后,依次按 ASCII 码值进行比较,最后将它们按升序输出。

sort 命令格式如下:

[root@localhost ~]# sort [选项] 文件名

选项:

  • -f:忽略大小写;

  • -b:忽略每行前面的空白部分;

  • -n:以数值型进行排序,默认使用字符串排序;

  • -r:反向排序;

  • -u:删除重复行。就是 uniq 命令;

  • -t:指定分隔符,默认分隔符是制表符;

  • -k [n,m]:按照指定的字段范围排序。从第 n 个字段开始,到第 m 个字(默认到行尾);

sort命令示例

sort 命令默认是用每行开头的第一个字符来进行排序的,比如:

复制代码

[root@localhost ~]# sort /etc/passwdabrt: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”选项,比如:

[root@localhost ~]# sort -r /etc/passwdvcsa: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/passwdbin:x:1:1:bin:/bin:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
abrt:x:173:173::/etc/abrt:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
…省略部分输出…

复制代码

指定分隔符是":",以第三个字段开头,以第三个字段结尾排序,也就是只用第三个字段排序
sort 默认是按照字符排序的,daemon 用户的 UID 是 2,前面用户的 UID 的第一个字符都是 1,所以daemon 用户排在了最后。如果要想按照数字排序,请使用"-n"选项,比如:

复制代码

[root@localhost ~]# sort -n -t":" -k 3,3 /etc/passwdroot:x:0:0: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/nologinlp:x:4:7:lp:/var/spod/lpd:/sbin/nologin
...省略部分输出...

复制代码

当然,"-k"选项可以直接使用"-k 3",代表从第三个字段到行尾都排序(第一个字段先排序,如果一致,则第二个字段再排序,直到行尾)。

 wc命令:统计指定文件中的字节数、字数、行数

命令格式如下:

[root@localhost ~]# wc [选项] 文件名

选项:

  • -l:只统计行数;

  • -w:只统计单词数;

  • -m:只统计字符数;

wc命令示例

统计一下 /etc_passwd 文件中到底有多少行、多个单词、多少个字符,命令如下:

[root@localhost ~]# wc /etc/passwd32 55 1537 /etc/passwd

统计服务器上有多少个正常连接 

[root@localhost ~]# netstat -an | grep ESTABLISHED | wc -l4