unix排序多个字段

时间:2011-06-14 01:20:19

标签: unix sorting field

我正在尝试按如下方式对文件进行排序:

col1(升序)col2(降序)col3(升序)col4(降序)

我想使用-k命令,而不是+-语法。 我已经想出如何使用旧语法:

sort -t " " +0 -1 +2 -3 +4r testfile

但这很难直观。 我还没有想出使用-k选项的正确方法。谢谢。

这是测试文件:

5 3 2 9
3 4 1 7
5 2 3 1
6 1 3 6
1 2 4 5
3 1 2 3
5 2 2 3

结果:

1 2 4 5
3 4 1 7
3 1 2 3
5 3 2 9
5 2 2 3
5 2 3 1
6 1 3 6

2 个答案:

答案 0 :(得分:28)

您需要以下其中一项:

sort --key=1,1 --key=2,2r --key=3,3 --key=4,4r
sort -k1,1 -k2,2r -k3,3 -k4,4r

如以下成绩单:

pax$ echo '5 3 2 9
3 4 1 7
5 2 3 1
6 1 3 6
1 2 4 5
3 1 2 3
5 2 2 3' | sort --key=1,1 --key=2,2r --key=3,3 --key=4,4r

1 2 4 5
3 4 1 7
3 1 2 3
5 3 2 9
5 2 2 3
5 2 3 1
6 1 3 6

如果您希望将它们视为正确的数字(可变长度),请记住提供-n选项,例如:

sort -n -k1,1 -k2,2r -k3,3 -k4,4r

答案 1 :(得分:0)

sort -n -k 1n -k 2rn -k 3n -k 4rn怎么样? -k <FIELD><OPT1><OPT2>...其中OPT1和OPt2只是sort选项,例如n是数字,r是反向的