fly2749 2024-03-21 21:01 采纳率: 50%
浏览 10

用java要实现一个txt转json的二维数组

我现在需要写一个txt转json的功能,json是二维数组,txt里面大概是这样的
batch | date | name | age


A 20240303 zhangsan 12
A 20240303 lisi 18
B 20240303 wangwu 23
A 20240304 zhaoliu 19

现在需要实现的是每个batch是一个大数组,即 A[],B[]
然后batch下对应的每个date是一个小数组
最终想要求得的结果是以下:
[{A:20240303:zhangsan:12,A:20240303:lisi:18},{A:20240304:zhaoliu:19}],[{B:20240303:wangwu:23}]

请给个思路 ,谢谢

  • 写回答

2条回答 默认 最新

  • 码农阿豪 Java领域优质创作者 2024-03-21 21:02
    关注
    让阿豪来帮你解答,本回答参考chatgpt3.5编写提供,如果还有疑问可以评论或留言
    思路:
    1. 首先读取txt文件,将每一行的数据进行处理,得到batch、date、name、age四个字段的值。
    2. 在处理过程中,先将batch作为key,判断其是否已经出现过,若未出现则创建以该batch为key的大数组;若已出现则将该batch对应的小数组取出。
    3. 将date、name、age组成一个对象,放入对应的小数组中。
    4. 最终得到的结果是一个以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" } ]
    ]
    
    评论

报告相同问题?

问题事件

  • 修改了问题 3月22日
  • 创建了问题 3月21日

悬赏问题

  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line