我正在努力合并两个数据集。我需要的是创建一个新的数组数组,其中包含下面两个数据集的合并。如果存在车辆类型匹配(即汽车),则第一个数据集将覆盖第二个数据集
数据集A - 要合并到数据集B
[ [ 'Cars', '', 'description here', 'true', '3' ],
[ 'Trucks', '', 'desc', 'true', '3' ],
[ 'Boats', '', 'desc', 'true', '3' ] ]
数据集B
[ { level: '3',
description: 'description here',
name: 'Cars',
availableForUse: false },
{ level: '3',
description: 'desc',
name: 'Trucks',
availableForUse: false },
{ level: '3',
description: 'desc',
name: 'Boats',
availableForUse: false },
{ level: '3',
description: 'desc',
name: 'Trains',
availableForUse: false } ]
到目前为止,我所做的是迭代数据集B,然后搜索数据集A进行匹配 - 如果匹配则数据集A中的数据应该进入新数组,数据集B中的相同数据应该是被省略。
到目前为止,这是我的代码,并没有给我这个结果。有了这段代码,我看到了重复的汽车。
for(var i = 0; i < datasetB.length; i++) {
for (var j = 0; j < datasetA.length; j++) {
if (datasetB[i].name == datasetA[j][0]) {
recordArray.push(datasetA[j][0], datasetA[j][1], datasetB[i].description, datasetA[j][3]);
servicesCollectionArray.push(recordArray);
datasetA.splice(j, 1);
recordArray = [];
if (datasetA.length < 1) {
break;
}
}
if (datasetB[i].name != datasetA[j][0]) {
recordArray.push(datasetB[i].name, "", datasetB[i].description, "false");
servicesCollectionArray.push(recordArray);
recordArray = [];
}
}
}
这是我用这段代码得到的:
[ [ 'Cars', '', 'description here', 'true' ],
[ 'Cars', '', 'description here', 'false' ],
[ 'Cars', '', 'description here', 'false' ],
[ 'Trucks', '', 'desc', 'true' ],
[ 'Trucks', '', 'desc', 'false' ],
[ 'Boats', '', 'desc', 'true' ] ]
这就是我想要的:
[ [ 'Cars', '', 'description here', 'true' ],
[ 'Trucks', '', 'desc', 'true' ],
[ 'Boats', '', 'desc', 'true' ],
[ 'Trains', '', 'desc', 'false' ] ]
答案 0 :(得分:1)
所以这里有两个问题。一个合并数据集&amp;另一个让结果独一无二的。
所以最好的办法就是拿第三桶。而我们挑选&amp;将所需的元素放入其中,只需检查它是否存在。
说d1&amp; d2是你的数组。然后让我们用一个临时对象来过滤掉。这使我们可以在推进时快速检查。
因为根据你的要求,d1有更多的偏好,我们首先迭代它。
最后,将所有内容都推送到结果数组中:
var t = {}, result = [];
d1.forEach(function (d) { if(!t[d[0]]) t[d[0]] = [d[0],d[2],d[3]]; });
d2.forEach(function (d) { if(!t[d.name]) t[d.name] = [d.name,d.description,d.availableForUse]; });
for(var i in t) result.push(t[i]);
// result holds your answer