【发布时间】:2019-05-26 03:25:37
【问题描述】:
我创建了一个 var rows 来生成一个 csv。 我想根据 2 列对内容进行排序:日期和时间。
DATE;TIME;ID;FACE;TOTAL;VAL1;VAL2;
07/05/2019;14:11:07;3234;0.00000038;2.00;-0.00000038;0;
07/05/2019;**16:11:07**;1779;0.00000019;2.00;-0.00000019;0;
07/05/2019;14:11:06;4120;0.00000304;2.00;0.00000304;1;
26/05/2019;**06:32:39**;2167;0.00000015;2.00;-0.00000015;0;
26/05/2019;06:32:38;5152;0.00000015;2.00;0.00000015;1;
**07/05/2019**;14:11:18;7949;0.00000038;2.00;-0.00000038;0;
预期结果:
DATE;TIME;ID;FACE;TOTAL;VAL1;VAL2;
07/05/2019;14:11:06;4120;0.00000304;2.00;0.00000304;1;
07/05/2019;14:11:07;3234;0.00000038;2.00;-0.00000038;0;
07/05/2019;14:11:18;7949;0.00000038;2.00;-0.00000038;0;
07/05/2019;16:11:07;1779;0.00000019;2.00;-0.00000019;0;
26/05/2019;06:32:38;2167;0.00000015;2.00;-0.00000015;0;
26/05/2019;06:32:39;5152;0.00000015;2.00;0.00000015;1;
var lines = rows.split('\n');
for(var loop = 0; loop < lines.length; loop++){
if (parseFloat(prev) > 0){val2= 1;}else {val2 = 0;}
(....)
lines[loop] = lines[loop].replace(/(\r\n|\n|\r|\s+)/gm,"").trim() + val1 + ";" + val2 + ";";
}
rows = lines.join('\n');
因为使用我的数组行很复杂,我正在考虑使用索引数组属性。但是lines不被认为是一个数组,所以forEach是不可用的。
var result = lines.reduce(function(r, a) {
a.forEach(function(s, i) {
var key = i === 0 ? 'headers' : 'col' + i;
r[key] || (r[key] = []);
r[key].push(s);
});
return r;
}, {});
function compare(r,x,col) {
if (r[x].col< r[x+1].col) return -1;
if (r[x].col > r[x+1].col) return 1;
return 0;
}
for(var loop = 0; loop < r.length; loop++){
result.sort(compare(r,loop,col1));
result.sort(compare(r,loop,col2));
}
如何应用双重排序标准并按预期获取此数组中的行?
我的代码用于谷歌浏览器。原型等一些功能不起作用(或过滤......)
【问题讨论】:
标签: javascript arrays sorting arraylist