拥有这种形式的二维数组:
arr = [
["12325-a", 1, 1, 1],
["43858-b", 3, 4, 1],
["84329-a", 6, 5, 2],
["18767-b", 0, 9, 0],
["65888-b", 5, 4, 4],
];
Run Code Online (Sandbox Code Playgroud)
在每个子数组上,第一个元素是一个字符串.
我想将具有相同结尾的子阵列组合在一起.在这种情况下,它将是两组: -a和-b.
应根据idex将数值计算为总和.
所以结果如下:
arr = [
["-a", 7, 6, 3],
["-b", 8, 17, 5],
];
Run Code Online (Sandbox Code Playgroud)
我的解决方案(不起作用):
let arr = [
["12325-a", 1, 1, 1],
["43858-b", 3, 4, 1],
["84329-a", 6, 5, 2],
["18767-b", 0, 9, 0],
["65888-b", 5, 4, 4],
];
result = arr.reduce(function(acc, curr) {
if (acc[curr[0].substr(curr[0].length - 2)]) {
acc[curr[0]] = acc[curr[0]].map(function(val, index) {
if (index) {
return val + curr[index];
}
return val;
});
} else {
acc[curr[0]] = curr;
}
return acc;
}, {});
console.log(result)Run Code Online (Sandbox Code Playgroud)
您可以首先使用reduce方法创建一个对象,然后Object.values获取一个值数组。
const arr = [
["12325-a", 1, 1, 1],
["43858-b", 3, 4, 1],
["84329-a", 6, 5, 2],
["18767-b", 0, 9, 0],
["65888-b", 5, 4, 4],
];
const result = arr.reduce((r, [str, ...rest]) => {
let key = str.split(/(\d+)/).pop();
if(!r[key]) r[key] = [key, ...rest];
else rest.forEach((e, i) => r[key][i + 1] += e)
return r;
}, {})
console.log(Object.values(result))Run Code Online (Sandbox Code Playgroud)