sort将文件的每一行作为一个单位,相互比较,比较原则是从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出。
常用选项:
t : tables 指定分隔符,默认tab为分隔符
-k: 指定安装哪一个分割区域进行排序
-o: output 将排序结果输出到源文件
-r : reverse 反向排序
-u : unique 唯一,排序并且排除重复项
-n : number 安照数字进行排序
-f:会将小写字母都转换为大写字母来进行比较,亦即忽略大小写
-c:会检查文件是否已排好序,如果乱序,则输出第一个乱序的行的相关信息,最后返回1
-C:会检查文件是否已排好序,如果乱序,不输出内容,仅返回1
-M:会以月份来排序,比如JAN小于FEB等等
-b:会忽略每一行前面的所有空白部分,从第一个可见字符开始比较。
事例文件:
事例1:
默认情况下sort命令以字母序进行排序:
事例2:
对数字进行排序,可以使用参数-n
# cat num.txt
100
20
3
# sort num.txt -n
3
20
100
事例3:
指定序列排序:sort排序的时候,可以按字段分割的数据进行排序。-t参数表示行的分割字符,-k表示第几列。当然,可以进行降序排序,-r参数可以实现。 下面是对passwd文件,以冒号(:)进行分割,然后对第三列以数字方式进行降序排序。
# sort -t ':' -k 3 -nr /etc/passwd
事例4:文件大小排序
在du的时候,加上-h可以使用易读性数字,比如2k,1g,3M这种。sort也支持-h参数。 比如,du一个文件夹下的目录大小后,想以文件大小进行排序。由于du -h的结果是3k,2M,1G这种,不能简单的按数字排序。所以,可以使用-h参数。
事例5:
系统进程占用排序:查看系统进程中,内存占用最多的前5个进程信息。
# ps aux|sort -gr -k 4|head -n 5
事例6:
对文件内容进行去重,使用-u参数
事例7:
将内容输出写入到文件,在shell中,一般将控制台内容写入文件,可以使用重定向,但如果想把sort的排序内容写回文件,则不能使用重定向。则需要-o参数。
#sort qq.txt -o qq.txt
之后