排序忽略第二个键的模式

排序忽略第二个键的模式

我正在尝试对包含此类条目的文件进行排序。

这是的输出head file.txt | sort -n

1       1       360030.650313113        23.6496749206273
1       2       184005.303709890        12.5819130584254
1       3       51304.4897339131        3.54834660232693
2       1       184005.303709890        12.5819130584254
2       2       176030.554401950        13.7621056226822
2       3       71841.9750474998        6.31576927490416
3       1       51304.4897339131        3.54834660232693
3       2       71841.9750474998        6.31576927490416
3       3       72642.2936524586        9.28260169486644
4       1       12511.6549282967        0.867004812539363

这是的输出cat file.txt | sort -n | head

1       100     0.265986106008280       1.948706529813553E-005
1       1000    3.184914160835964E-004  3.067021647295356E-008
1       1001    7.604450718679718E-005  7.326181191420022E-009
1       1002    1.809620185415599E-005  1.743513966528432E-009
1       1003    4.304204593193070E-006  4.147009800188772E-010
1       1004    1.023686141641656E-006  9.863012681974230E-011
1       1005    2.434647501464963E-007  2.345735005737759E-011
1       1006    5.790348098792519E-008  5.578886733501962E-012
1       1007    1.377124338943865E-008  1.326832274761822E-012
1       1008    3.275228617666499E-009  3.155618499463635E-013

正如您所看到的,如果我只使用文件的一小部分,输出会完全按照我想要的方式排序,但是当我使用整个文件时,不知怎的,100 出现在 1 之前。我尝试指定,-k1,2但也-k1n,2n无济于事。

我该怎么做才能让整个文件像 1,1; 一样排序? 1,2; 1,3 ... 1,2000; 2,1; 2,2; ... 2,2000; ETC?

我的排序版本是 sort (GNU coreutils) 8.21(如果相关的话)。

答案1

您可以逐个字段地移动:

sort -k1,1n -k2,2n -k3,3n -k4,4n file.txt

这将sort首先根据第一个字段进行数字排序,如果多行字段相同,那么它们将根据第二个字段进行排序,依此类推,直到最后。您可以修改订单以满足您的需要。

相关内容