sort命令:用於將文本文件內容加以排序,sort可針對文本文件的內容,以行為單位來排序。
命令格式:
sort [-bcdfimMnr][-o<輸出文件>][-t<分隔字符>][+<起始欄位>-<結束欄位>][--help][--verison][文件]
常見參數:
- -b 忽略每行前面開始出的空格字符。
- -c 檢查文件是否已經按照順序排序。
- -d 排序時,處理英文字母、數字及空格字符外,忽略其他的字符。只考慮空格、字母和數字
- -f 排序時,將小寫字母視為大寫字母。
- -i 排序時,除了040至176之間的ASCII字符外,忽略其他的字符。只考慮可打印字符。
- -m 將幾個排序好的文件進行合並。
- -M 將前面3個字母依照月份的縮寫進行排序。
- -n 依照數值的大小排序;對指定的列進行排序,+0表示第一列,以空格或制表符作為列的間隔符。
- -o<輸出文件> 將排序后的結果存入指定的文件。
- -u 去重,配合-c,嚴格校驗排序;不配合-c,則只輸出一次排序結果,一般用uniq代替。
- -r 倒序(降序)以相反的順序來排序。
- -t<分隔字符> 指定排序時所用的欄位分隔字符。例如:-t. 表示按點號分隔域,類似於awk -F或cut -d
- -k指定第幾列或第幾列的第幾個字符。與-t配合使用
- +<起始欄位>-<結束欄位> 以指定的欄位來排序,范圍由起始欄位到結束欄位的前一欄位。
- --help 顯示幫助。
- --version 顯示版本信息。
測試:
去重:
[root@bqh-118 ~]# cat qc.log
192.168.43.117
192.168.43.119
192.168.43.118
192.168.43.118
192.168.43.117
192.168.43.117
192.168.43.119
192.168.43.110
[root@bqh-118 ~]# sort -u qc.log
192.168.43.110
192.168.43.117
192.168.43.118
192.168.43.119
注:-u,一般用uniq代替。
去重+降序(倒序)排序:
[root@bqh-118 ~]# sort -ur qc.log
192.168.43.119
192.168.43.118
192.168.43.117
192.168.43.110
按數字排序:
[root@bqh-118 ~]# sort -n qc.log
192.168.43.110
192.168.43.117
192.168.43.117
192.168.43.117
192.168.43.118
192.168.43.118
192.168.43.119
192.168.43.119
注:默認為升序。
按數字倒序排序
[root@bqh-118 ~]# sort -r qc.log
192.168.43.119
192.168.43.119
192.168.43.118
192.168.43.118
192.168.43.117
192.168.43.117
192.168.43.117
192.168.43.110
指定分隔符排序:按對應的列排序
-k, --key=pos1[pos2]
start a key at pos1 (orign 1), end it at pos2 (default end of line)
1. 默認按整行排序。
2. -t指定分隔符,-k1,分隔符之后的第一列排序
3. -k 1,1 用逗號來分隔字段,表示第一個字段開始排序到第一個字段結束
4. -k 1.1,3.3 用點分隔字符。表示第一個字段的第一個字符開始排序到第三個字段的第三個字符結束。
[root@bqh-118 ~]# cat qc3.log
192.168.43.117 a
192.168.43.119 d
192.168.43.118 z
192.168.43.118 n
192.168.43.117 o
192.168.43.117 m
192.168.43.119 k
192.168.43.110 l
[root@bqh-118 ~]# sort -t" " -k2 qc3.log
192.168.43.117 a
192.168.43.119 d
192.168.43.119 k
192.168.43.110 l
192.168.43.117 m
192.168.43.118 n
192.168.43.117 o
192.168.43.118 z
[root@bqh-118 ~]# sort -k2 qc3.log
192.168.43.117 a
192.168.43.119 d
192.168.43.119 k
192.168.43.110 l
192.168.43.117 m
192.168.43.118 n
192.168.43.117 o
192.168.43.118 z
注:分隔符默認為空格,-t可省略,所有上邊命令可以sort -k2 qc3.log
[root@bqh-118 ~]# cat qc4.log
192.168.0.1 00:OF:AF:45:4C:78
192.168.0.71 00:OF:1AF:45:4C:76
192.168.0.16 00:OF:KF:55:S6:25
192.168.0.99 00:LF:9F:R5:IC:27
192.168.0.91 00:OF:H6:45:A1:67
192.168.0.65 00:O1:W3:45:49:94
192.168.0.89 00:OF:A8:33:V5:90
192.168.0.31 00:90:32:J9:1L:14
192.168.0.19 00:OF:76:29:30:DF
192.168.0.177 00:OF:12:09:P9:41
192.168.0.121 00:YF:A2:U7:4O:RT
192.168.0.253 00:OF:SD:40:J3:19
192.168.0.51 00:II:V5:39:47:OI
192.168.0.46 00:OF:A3:81:D3:1Y
192.168.0.7 00:OI:W1:IW:H7:B1
192.168.0.189 00:OF:S5:00:12:70
192.168.0.155 00:OY:TF:4Q:46:8M
[root@bqh-118 ~]# sort -t. -k4,4nr qc4.log #從第4個字段開始排序,到第4個字段結束排序,按數字降序
192.168.0.253 00:OF:SD:40:J3:19
192.168.0.189 00:OF:S5:00:12:70
192.168.0.177 00:OF:12:09:P9:41
192.168.0.155 00:OY:TF:4Q:46:8M
192.168.0.121 00:YF:A2:U7:4O:RT
192.168.0.99 00:LF:9F:R5:IC:27
192.168.0.91 00:OF:H6:45:A1:67
192.168.0.89 00:OF:A8:33:V5:90
192.168.0.71 00:OF:1AF:45:4C:76
192.168.0.65 00:O1:W3:45:49:94
192.168.0.51 00:II:V5:39:47:OI
192.168.0.46 00:OF:A3:81:D3:1Y
192.168.0.31 00:90:32:J9:1L:14
192.168.0.19 00:OF:76:29:30:DF
192.168.0.16 00:OF:KF:55:S6:25
192.168.0.7 00:OI:W1:IW:H7:B1
192.168.0.1 00:OF:AF:45:4C:78
[root@bqh-118 ~]# sort -t. -k3.1,4.1nr qc4.log #從第三個字段第一個字符排序,到第四個字段第一個字符結束,按數字降序
192.168.0.91 00:OF:H6:45:A1:67
192.168.0.99 00:LF:9F:R5:IC:27
192.168.0.89 00:OF:A8:33:V5:90
192.168.0.7 00:OI:W1:IW:H7:B1
192.168.0.71 00:OF:1AF:45:4C:76
192.168.0.65 00:O1:W3:45:49:94
192.168.0.51 00:II:V5:39:47:OI
192.168.0.46 00:OF:A3:81:D3:1Y
192.168.0.31 00:90:32:J9:1L:14
192.168.0.253 00:OF:SD:40:J3:19
192.168.0.1 00:OF:AF:45:4C:78
192.168.0.121 00:YF:A2:U7:4O:RT
192.168.0.155 00:OY:TF:4Q:46:8M
192.168.0.16 00:OF:KF:55:S6:25
192.168.0.177 00:OF:12:09:P9:41
192.168.0.189 00:OF:S5:00:12:70
192.168.0.19 00:OF:76:29:30:DF
