javascript - 嵌套 Object.keys forEach 循环和构建合并 JSON 对象数组的问题
问题描述
我有两个 CSV 文件,一个带有路由步骤,一个带有 id 列表。我需要将每个 id 添加到每个路由步骤的开头。我正在使用 Node.js。
var routeNumFile = '/routing_numbers.csv';
var routeStepFile = '/routing_steps.csv';
const csvToJson = require('csvtojson');
const jsonToCsv = require('json2csv').parse;
const fs = require('fs');
var routeNumArray;
var routeStepArray;
try {
routeNumArray = await csvToJson().fromFile(routeNumFile);
} catch (err) {
console.log("error in reading csv file")
}
try {
routeStepArray = await csvToJson().fromFile(routeStepFile);
} catch (err) {
console.log("error in reading csv file")
}
var outputArray = new Array;
var outputPath = '/gitlab/BSI_Create_Csv_Import/finalOutput.csv';
if (routeNumArray != null && routeStepArray != null) {
Object.keys(routeNumArray).forEach(function (key1) {
Object.keys(routeStepArray).forEach(function (key2) {
var comboObj = Object.assign(routeNumArray[key1], routeStepArray[key2]);
console.log(comboObj);
outputArray.push(comboObj);
});
});
}
console.log(outputArray);
var csv = jsonToCsv(outputArray);
fs.writeFileSync(outputPath, csv);
console.log(comboObj) 的输出是我想要的。但是,当我将其放入数组时,我只会一遍又一遍地获得路由步骤 CSV 中的最后一个条目。如果我直接在创建 comboObj 的位置使用流编写它,它主要工作。如果我这样做,我首先将对象转换为 CSV,输出让我在每一行的末尾都有重复的标题。它将 JSON 对象数组更清晰地写入 CSV。
因此,我试图将所有组合对象放在一个数组中,以便我可以将其全部转换为 CSV 并将其写入文件。谁能告诉我我的方法出了什么问题?
解决方案
您应该创建一个新对象并为其分配属性,如下所示:
var comboObj = Object.assign({}, routeNumArray[key1], routeStepArray[key2]);
推荐阅读
- node.js - Mongo DB on watch,发送附加字段
- vim - Vim 文本替换
- python - 使用列表中的值以基于现有数据框创建一些新的数据框
- python - 显示来自循环的排序结果
- ios - 禁用 UITableView 中特定 UITableViewCell 的删除选项
- python - 创建人口数据
- javascript - Chrome 扩展程序:如何触发用户看不到的链接
- ios - 游戏期间屏幕变得无响应 - Xcode iOS
- python - 在 Jupyter 中并排显示交互式绘图和 Markdown 文本
- javascript - 工具提示不起作用 bootstrap 5 wordpress-gulp-starter-kit