javascript - 根据查找值对二维数组中的值求和 - Javascript
问题描述
我有两个数组:
const array = [
[1, 7, 'AAA'],
[2, 5, 'BBB'],
[3, 2, 'CCC'],
[4, 4, 'DDD'],
[4, 9, 'EEE'],
[4, 2, 'FFF'],
[5, 8, 'GGG'],
[6, 2, 'HHH']];
const names = [
[1, 'Joe'],
[2, 'Dave'],
[3, 'Mike'],
[4, 'Sandra'],
[5, 'Sue'],
[6, 'Mary']];
根据第一列中的值,我想对数组 [1] 中的值求和并列出三个字符的字母。我想要得到的结果是:
const names = [
[1, 'Joe',7,'AAA'],
[2, 'Dave',5,'BBB'],
[3, 'Mike',2,'CCC'],
[4, 'Sandra',15,'DDD, EEE, FFF'],
[5, 'Sue',8,'GGG'],
[6, 'Mary',2,'HHH']]
我不确定最好的方法,我对 Javascript 还很陌生。我设法做的是当数组 [0] 中的值不重复时得到正确的结果,但我无法得到一个总和或列表来工作。
const counter = (array,value) => array.filter((v) => (v === value)).length;
const arrayCol = (array,value) => array.map(v => v[value]);
const sum = (prevVal, curVal) => prevVal + curVal;
names.forEach ((p,e) => {
array.forEach ((v,x) => (counter(arrayCol(array,0),v[0])===1) ?
(v[0]===p[0]) && names[e].push(v[1],v[2]) :
(v[0]===p[0]) && names[e].push(array.reduce(sum,0)) );
});
console.log(names);
我确定答案与map
或filter
但不确定如何...任何指针表示赞赏。谢谢
编辑:以下所有三个答案(来自Michael Haddad、Nina Scholz和testing_22)都有效并且很有趣。
解决方案
您可以使用 map 和 reduce 的组合,如下所示:
const array = [[1, 7, 'AAA'], [2, 5, 'BBB'], [3, 2, 'CCC'],[4, 4, 'DDD'], [4, 9, 'EEE'], [4, 2, 'FFF'], [5, 8, 'GGG'], [6, 2, 'HHH']];
const names = [[1, 'Joe'],[2, 'Dave'],[3, 'Mike'],[4, 'Sandra'],[5, 'Sue'],[6, 'Mary']];
const result = names.map(([id, name]) => {
let vals = [];
let sum = array.reduce((acc, [idx, number, XXX]) =>
(idx === id ? (vals.push(XXX), number) : 0) + acc, 0);
return [
id,
name,
sum,
vals.join(", ")
]
})
console.log(result)
推荐阅读
- javascript - I still can't get my callbacks to work when using Ajax. It doesn't seem to be waiting for the callback, what am I doing wrong?
- java - 尝试在 TextView 中显示 EditText 值时的空对象引用 - Android
- python - 如何从 GYM 制作用户可以使用键盘玩的手推车游戏
- python - ValueErro:x 和 y 的大小必须相同
- clojure - 如何在 clojure 中添加类型提示来修复“ctor can't be resolved”反射警告,即调用构造函数?
- javascript - React - 将api调用结果返回给原始函数
- vba - 错误处理 For 循环 - 下标超出范围
- list - 循环查询集不会追加到列表
- lua - 如何在 Roblox Lua 中制作 2D GUI?
- sql - Postgres 查询 DISTINCT 两列中的任何一列