请不要认为这是"在unix中排序字母数字数据"问题...我看了其他答案,并认为我的情况有点不同!
我有这样的数据:
A 192
D 112
D 188
C 091
A 281
B 919
...我想按第1列(按字母顺序)排序,然后按第2列排序(按数字排序)。我尝试使用:
sort -n -k1,2
...但是这给了我正确排序的第一个字段,但是第二个字段的排序错误(1000,1002,1003,10,1 ...而不是1,10,1000,1002,1003 )。
有人可以建议如何按照我喜欢的方式对这两列进行排序吗?
答案 0 :(得分:36)
尝试使用如下: -
sort -k1,1 -k4,4n
- -n:根据数值
对程序进行排序- -k opts:使用给定的列号对数据/字段进行排序。例如,选项-k 2使用第二个选项对程序进行排序 数据列。选项-k 3,3n -k 4,4n对每列进行排序。首先
它将排序第3列,然后排序第4列。
答案 1 :(得分:6)
这应该有效:
sort -t "," -k1,1 -k2n,2 file