Reshape JSON using lodash and reduce

前端 未结 1 1108
灰色年华
灰色年华 2021-01-21 22:59

I want to reshape a JSON from a parsed CSV file downloaded from an URL.

I used \'csvtojson\' module to parse CSV and create a JSON that need to be reshaped.

Below

1条回答
  •  栀梦
    栀梦 (楼主)
    2021-01-21 23:42

    From the post and your comments I assumed your response data will be something like below and as far as I understand from your comments, you want to group the values by date from datetime and then having the multiple objects inside the values array of a group according to different hour basis. I tried it with lodash groupBy function. For solution, I approached with two grouping

    1. group by date from datetime
    2. group values of times of each group date

    let data = [
        {
            "datetime": "2020-06-29T23:59:59.000Z",
            "Benzene": 1.9
        },
        {
            "datetime": "2020-06-30T00:59:59.000Z",
            "Benzene": 0.6
        },
        {
            "datetime": "2020-06-30T01:59:59.000Z",
            "Benzene": 5.7
        },
        {
            "datetime": "2020-06-30T02:59:59.000Z",
            "Benzene": 5.5
        },
        {
            "datetime": "2020-06-30T03:59:59.000Z",
            "Benzene": 5.2
        },
        {
            "datetime": "2020-06-30T04:59:59.000Z",
            "Benzene": 1
        },
        {
            "datetime": "2020-06-30T05:59:59.000Z",
            "Benzene": 2.1
        },
        {
            "datetime": "2020-06-30T06:59:59.000Z",
            "Benzene": 4.2
        },
        {
            "datetime": "2020-06-30T07:59:59.000Z",
            "Benzene": 3.4
        },
        {
            "datetime": "2020-06-30T00:59:59.000Z",
            "NO2": 16.3
        },
        {
            "datetime": "2020-06-30T01:59:59.000Z",
            "NO2": 12.6
        },
        {
            "datetime": "2020-06-30T02:59:59.000Z",
            "NO2": 11.7
        },
        {
            "datetime": "2020-06-30T03:59:59.000Z",
            "NO2": 35.5
        },
        {
            "datetime": "2020-06-30T04:59:59.000Z",
            "NO2": 44.6
        },
        {
            "datetime": "2020-06-30T05:59:59.000Z",
            "NO2": 19.9
        },
        {
            "datetime": "2020-06-30T06:59:59.000Z",
            "NO2": 11.2
        },
        {
            "datetime": "2020-06-30T07:59:59.000Z",
            "NO2": 8.2
        },
        {
            "datetime": "2020-06-29T23:59:59.000Z",
            "O3": 25.6
        },
        {
            "datetime": "2020-06-30T01:59:59.000Z",
            "O3": 31.7
        },
        {
            "datetime": "2020-06-30T02:59:59.000Z",
            "O3": 35.1
        },
        {
            "datetime": "2020-06-30T03:59:59.000Z",
            "O3": 11.4
        },
        {
            "datetime": "2020-06-30T04:59:59.000Z",
            "O3": 4.9
        },
        {
            "datetime": "2020-06-30T05:59:59.000Z",
            "O3": 32.8
        },
        {
            "datetime": "2020-06-30T06:59:59.000Z",
            "O3": 46.4
        },
        {
            "datetime": "2020-06-30T07:59:59.000Z",
            "O3": 55.6
        }
    ];
    const groupsByDate = _.groupBy(data, val => val.datetime.split('T')[0]);
    const res = Object.entries(groupsByDate).map(([date, vals]) => {
      const groupsByTime = _.groupBy(vals, val => val.datetime.split('T')[1]);
      return {
        date,
        values: Object.values(groupsByTime).map(arr => Object.assign({}, ...arr))
      };
    });
    
    console.log(JSON.stringify(res, null, 2));

    I also tried to put my solution into your current approach

    const json_from_csv_filtered = [
        {
            "datetime": "2020-06-29T23:59:59.000Z",
            "Benzene": 1.9
        },
        {
            "datetime": "2020-06-30T00:59:59.000Z",
            "Benzene": 0.6
        },
        {
            "datetime": "2020-06-30T01:59:59.000Z",
            "Benzene": 5.7
        },
        {
            "datetime": "2020-06-30T02:59:59.000Z",
            "Benzene": 5.5
        },
        {
            "datetime": "2020-06-30T03:59:59.000Z",
            "Benzene": 5.2
        },
        {
            "datetime": "2020-06-30T04:59:59.000Z",
            "Benzene": 1
        },
        {
            "datetime": "2020-06-30T05:59:59.000Z",
            "Benzene": 2.1
        },
        {
            "datetime": "2020-06-30T06:59:59.000Z",
            "Benzene": 4.2
        },
        {
            "datetime": "2020-06-30T07:59:59.000Z",
            "Benzene": 3.4
        },
        {
            "datetime": "2020-06-30T00:59:59.000Z",
            "NO2": 16.3
        },
        {
            "datetime": "2020-06-30T01:59:59.000Z",
            "NO2": 12.6
        },
        {
            "datetime": "2020-06-30T02:59:59.000Z",
            "NO2": 11.7
        },
        {
            "datetime": "2020-06-30T03:59:59.000Z",
            "NO2": 35.5
        },
        {
            "datetime": "2020-06-30T04:59:59.000Z",
            "NO2": 44.6
        },
        {
            "datetime": "2020-06-30T05:59:59.000Z",
            "NO2": 19.9
        },
        {
            "datetime": "2020-06-30T06:59:59.000Z",
            "NO2": 11.2
        },
        {
            "datetime": "2020-06-30T07:59:59.000Z",
            "NO2": 8.2
        },
        {
            "datetime": "2020-06-29T23:59:59.000Z",
            "O3": 25.6
        },
        {
            "datetime": "2020-06-30T01:59:59.000Z",
            "O3": 31.7
        },
        {
            "datetime": "2020-06-30T02:59:59.000Z",
            "O3": 35.1
        },
        {
            "datetime": "2020-06-30T03:59:59.000Z",
            "O3": 11.4
        },
        {
            "datetime": "2020-06-30T04:59:59.000Z",
            "O3": 4.9
        },
        {
            "datetime": "2020-06-30T05:59:59.000Z",
            "O3": 32.8
        },
        {
            "datetime": "2020-06-30T06:59:59.000Z",
            "O3": 46.4
        },
        {
            "datetime": "2020-06-30T07:59:59.000Z",
            "O3": 55.6
        }
    ];
    const groupBy = (xs, f) => {
      return xs.reduce((acc, val) => {
              const key = f(val);
              const values = [...(acc[key] || []), val];
              acc[key] = values;
              return acc;
          }, {});
    }
    
    const groupsByDate = groupBy(json_from_csv_filtered, v => v.datetime.split("T")[0]);
    const res = Object.entries(groupsByDate).map(([date, values]) => {
      const groupsByTime = groupBy(values, v => v.datetime.split("T")[1]);
      return {
        date,
        values: Object.values(groupsByTime).map(v => Object.assign({}, ...v))
      };
    });
    console.log(JSON.stringify(res, null, 2));

    Check the approach and I hope it will solve your problem as per my understanding.

    0 讨论(0)
提交回复
热议问题