linux 中 sort -k选项
001、简单测试
[root@PC1 test1]# ls a.txt [root@PC1 test1]# cat a.txt ## 测试数据 01 02 03b 34 05 86 87a 98 09 10 41b 12 13 54 15i 16 17 18 19a 20 [root@PC1 test1]# sort -k 4 a.txt ## 按照第四列进行排序 09 10 41b 12 13 54 15i 16 17 18 19a 20 01 02 03b 34 05 86 87a 98 [root@PC1 test1]# sort -k 3 a.txt ## 按照第三列继续排序 01 02 03b 34 13 54 15i 16 17 18 19a 20 09 10 41b 12 05 86 87a 98
。
002、-k域的字段
[root@PC1 test1]# ls a.txt [root@PC1 test1]# cat a.txt ## 测试数据 01 02 03b 34 05 86 87a 98 09 10 41b 12 13 54 15i 16 17 18 19a 20 [root@PC1 test1]# sort -k 3.3,3.3 a.txt ## 指定第三个域的第三个字符排序,无效 09 10 41b 12 01 02 03b 34 13 54 15i 16 05 86 87a 98 17 18 19a 20 [root@PC1 test1]# sort -t " " -k 3.3,3.3 a.txt ## 使用-t选项指定域的分隔符,生效, 为什么? 05 86 87a 98 17 18 19a 20 01 02 03b 34 09 10 41b 12 13 54 15i 16
。
003、
[root@PC1 test1]# ls a.txt [root@PC1 test1]# cat a.txt ## 测试数据 01 02 03b 34 05 86 87a 98 09 10 41b 12 13 54 15i 16 17 18 19a 20 [root@PC1 test1]# sort -k 2.2 a.txt ## 依据第二个字段的第二个字符排序 01 02 03b 34 09 10 41b 12 17 18 19a 20 13 54 15i 16 05 86 87a 98 [root@PC1 test1]# sort -t " " -k 2.2 a.txt ## 使用-t选项指定空格为分隔符生效 09 10 41b 12 01 02 03b 34 13 54 15i 16 05 86 87a 98 17 18 19a 20
。
004、
[root@PC1 test1]# ls a.txt [root@PC1 test1]# cat a.txt ## 测试数据 01 02 03b 34 05 86 87a 98 09 10 41b 12 13 54 15i 16 17 18 19a 20 [root@PC1 test1]# sort -k 2.2 a.txt ## 无效 01 02 03b 34 09 10 41b 12 17 18 19a 20 13 54 15i 16 05 86 87a 98 [root@PC1 test1]# sort -t "\t" -k 2.2 a.txt ## 指定制表符分隔符,无效 sort: multi-character tab ‘\\t’ [root@PC1 test1]# sort -t $'\t' -k 2.2 a.txt ## 指定制表符分隔符 09 10 41b 12 01 02 03b 34 13 54 15i 16 05 86 87a 98 17 18 19a 20
。
005、
[root@PC1 test1]# ls a.txt [root@PC1 test1]# cat a.txt ## 测试数据 01 02 03b 34 05 86 87a 98 09 10 41b 12 13 54 15i 16 17 18 19a 20 [root@PC1 test1]# sort -t $'\t' -k 2.2 a.txt ## 按照第二个字段的第二个字符开始排序 09 10 41b 12 01 02 03b 34 13 54 15i 16 05 86 87a 98 17 18 19a 20 [root@PC1 test1]# sort -t $'\t' -kr 2.2 a.txt ## 逆向排序指定失败 sort: invalid number at field start: invalid count at start of ‘r’ [root@PC1 test1]# sort -t $'\t' -k 2.2r a.txt ## 逆向排序 17 18 19a 20 05 86 87a 98 13 54 15i 16 01 02 03b 34 09 10 41b 12
。