我需要从文件“test”(数据示例)中对一些数据进行排序:
1.03073 0.000193333 2.02417 2.15578
1.03073 0.0002 2.12005 2.14534
1.03073 1.33333e-05 100 0
1.03073 2e-05 100 0
这样它首先在第一列上排序,然后在第二列上排序。 我试过
sort -n -k1 -k2 -u test >test1
但是因为他没有看到“e-5”的一部分而搞得一团糟。 有什么想法吗?
答案 0 :(得分:6)
您可以使用-g
:
sort -k1,2 -g file
来自man sort
:
-g, - general-numeric-sort
根据一般数值进行比较
$ cat a
1.03073 0.000193333 2.02417 2.15578
1.03073 0.0002 2.12005 2.14534
1.03073 1.33333e-05 100 0
1.03073 2e-05 100 0
1.03073 2e-04 100 0
1.03073 2e-06 100 0
$ sort -k1,2 -g a
1.03073 0.000193333 2.02417 2.15578
1.03073 0.0002 2.12005 2.14534
1.03073 1.33333e-05 100 0
1.03073 2e-04 100 0
1.03073 2e-05 100 0
1.03073 2e-06 100 0