使用Node/JS合并两个数据集

Merge two datasets using Node/JS

本文关键字:两个 数据集 Node JS 合并 使用      更新时间:2023-09-26

我正在努力合并两个数据集。我需要的是创建一个新的数组,其中包含下面两个数据集的合并。如果车辆类型(即汽车)匹配,则第一个数据集覆盖第二个数据集

数据集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' ] ]

所以这里有两个问题。。合并数据集&另一种是使结果独一无二。

所以最好的办法是拿第三桶。当我们选择&将所需的元素放入其中,只需检查其是否存在即可。

说d1&d2是你的数组。然后让我们取一个临时对象t来过滤掉。这使我们能够在推入时快速检查。

由于根据您的要求,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