可以使用科学记数法对表进行排序的JavaScript库

时间:2012-05-11 18:34:26

标签: javascript html

我正在为我的表使用javascript类sorttable(参见:http://www.kryogenix.org/code/browser/sorttable/

但是,我有一张使用科学记数法的表格。当我对列进行排序时,它看起来像这样......

9.43947E-20
9.41332E-22
9.36423E-22
9.35113E-18
9.2744E-23
9.18754E-22
9.09174
8.3981E-22
7.72743E-19
7.69538E-18
7.23656E-19

没有正确排序。我希望它看起来像这样......

9.09174
9.35113E-18
7.69538E-18
7.72743E-19
7.23656E-19
9.43947E-20
9.41332E-22
9.36423E-22
8.3981E-22
9.2744E-23

是否有可以执行此操作的javascript函数?感谢。

4 个答案:

答案 0 :(得分:2)

上面的代码可以使用我的sorTable库(当前在后面也使用jQuery):

演示:http://jsfiddle.net/bBJBa/1/

他们的关键是使用*1parseFloat而不是parseInt将字符串值转换为数字。

答案 1 :(得分:1)

var myArrayOfNumbersAsStrings.sort(function(a,b){
    if(parseFloat(a) < parseFloat(b)) return -1;
    if(parseFloat(a) > parseFloat(b)) return 1;
    return 0;
});

答案 2 :(得分:1)

试试这个:

numbers.sort(function(a, b) {
  return Number(a) - Number(b);
}); // => The array "numbers" is now sorted numerically ascending.

答案 3 :(得分:0)

您希望它们从最大到最小排序 -

   var A= [
        '9.43947E-20',
        '9.41332E-22',
        '9.36423E-22',
        '9.35113E-18',
        '9.2744E-23',
        '9.18754E-22',
        '9.09174',
        '8.3981E-22',
        '7.72743E-19',
        '7.69538E-18',
        '7.23656E-19'
    ];
    A.sort(function(a, b){
        return b-a;
    }).join('\n')

    /*  returned value: (String)
    9.09174
    9.35113E-18
    7.69538E-18
    7.72743E-19
    7.23656E-19
    9.43947E-20
    9.41332E-22
    9.36423E-22
    9.18754E-22
    8.3981E-22
    9.2744E-23
    */