如何在unix中按字母和数字对不同字段的文件进行排序?

时间:2013-08-12 17:48:36

标签: unix sorting

请不要认为这是"在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 )。

有人可以建议如何按照我喜欢的方式对这两列进行排序吗?

2 个答案:

答案 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