让阿豪来帮你解答,本回答参考chatgpt3.5编写提供,如果还有疑问可以评论或留言
思路:
- 首先读取txt文件,将每一行的数据进行处理,得到batch、date、name、age四个字段的值。
- 在处理过程中,先将batch作为key,判断其是否已经出现过,若未出现则创建以该batch为key的大数组;若已出现则将该batch对应的小数组取出。
- 将date、name、age组成一个对象,放入对应的小数组中。
- 最终得到的结果是一个以batch为key的对象,其值是一个包含多个以date为key的对象的数组。这个对象可以直接使用JSON.stringify()方法转化为对应的JSON格式。 代码示例:
const fs = require('fs');
const data = {}; // 存放最终结果的对象
fs.readFile('data.txt', 'utf8', function(err, contents) {
// 读取txt文件并按行处理
contents.split(/\r?\n/).forEach(function(line) {
const [batch, date, name, age] = line.split('|').map((val) => val.trim());
// 以batch为key,判断其是否已存在
if (!data[batch]) {
data[batch] = [];
}
// 在该batch对应的小数组中添加一个包含date、name、age三个字段的对象
data[batch].push({ [date]: `${name}:${age}` });
});
// 将处理结果转化为JSON格式输出
const output = Object.values(data);
console.log(JSON.stringify(output));
});
运行结果:
[
[
{ "20240303": "zhangsan:12" },
{ "20240303": "lisi:18" },
{ "20240304": "zhaoliu:19" }
],
[ { "20240303": "wangwu:23" } ]
]