如何在bash中使用指数对两列进行排序

时间:2014-08-20 14:38:01

标签: bash sorting double

我需要从文件“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”的一部分而搞得一团糟。 有什么想法吗?

1 个答案:

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