我正在为我的表使用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函数?感谢。
答案 0 :(得分:2)
上面的代码可以使用我的sorTable库(当前在后面也使用jQuery):
他们的关键是使用*1
或parseFloat
而不是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
*/