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

标签 javascript node.js merge

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

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

关于javascript - 使用 Node/JS 合并两个数据集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34573747/

相关文章:

javascript - 如何在 IntelliJ Idea 中调试 NodeJS 应用程序?

javascript - 使用 typescript 时如何处理快速 Controller 方法参数?

javascript - 为什么 Phantom.js 不评估我的 Backbone 应用程序的工作?

python - Pandas : merge on column of ByteArray

javascript - Javascript 中的 Date().toDateString() 是什么日期格式?

javascript - 在幻灯片上插入覆盖的 Div

javascript - 使用 JavaScript 中的数据值创建 DOM 元素

javascript - jQuery 构造函数中的函数有什么不同吗?

merge - wiki 如何处理多个同时编辑?

Unix:使用第二列合并2个文件