Выдвинуть объект в массив объектов, значение которых равно - PullRequest
0 голосов
/ 20 октября 2019

У меня есть массив объектов, которые выглядят так:

Я хочу добавить объекты на основе site_nm. Я хочу быть в состоянии выровнять этот массив объектов. Я хочу добавить равное количество объектов для каждого site_nm, увеличивая дату. Итак, я делаю:

let data = [{
  "site_nm": "gs Universe",
  "date": "2019-10-01",
  "sigh": 1,
  "yo": 1,
  "wokay": 0
}, {
  "site_nm": "gs Gameplay",
  "date": "2019-10-01",
  "sigh": 4,
  "yo": 3,
  "wokay": 2
}, {
  "site_nm": "gs Universe Trailers",
  "date": "2019-10-01",
  "sigh": 5,
  "yo": 5,
  "wokay": 0
}, {
  "site_nm": "TR",
  "date": "2019-10-01",
  "sigh": 4,
  "yo": 4,
  "wokay": 0
}, {
  "site_nm": "gs",
  "date": "2019-10-01",
  "sigh": 5,
  "yo": 5,
  "wokay": 2
}, {
  "site_nm": "GB",
  "date": "2019-10-01",
  "sigh": 1,
  "yo": 1,
  "wokay": 1
}, {
  "site_nm": "cn",
  "date": "2019-10-01",
  "sigh": 4,
  "yo": 4,
  "wokay": 1
}, {
  "site_nm": "Roadshow",
  "date": "2019-10-01",
  "sigh": 1,
  "yo": 1,
  "wokay": 0
}, {
  "site_nm": "TV",
  "date": "2019-10-01",
  "sigh": 1,
  "yo": 1,
  "wokay": 0
}, {
  "site_nm": "ZD",
  "date": "2019-10-01",
  "sigh": 2,
  "yo": 2,
  "wokay": 0
}, {
  "site_nm": "Carfection",
  "date": "2019-10-01",
  "sigh": 1,
  "yo": 1,
  "wokay": 0
}, {
  "site_nm": "gs Trailers",
  "date": "2019-10-01",
  "sigh": 3,
  "yo": 3,
  "wokay": 0
}, {
  "site_nm": "gs News",
  "date": "2019-10-01",
  "sigh": 3,
  "yo": 3,
  "wokay": 0
}, {
  "site_nm": "gs Mobile",
  "date": "2019-10-01",
  "sigh": 1,
  "yo": 1,
  "wokay": 0
}, {
  "site_nm": "gs Universe Trailers",
  "date": "2019-10-02",
  "sigh": 1,
  "yo": 1,
  "wokay": 0
}, {
  "site_nm": "gs Gameplay",
  "date": "2019-10-04",
  "sigh": 6,
  "yo": 6,
  "wokay": 2
}, {
  "site_nm": "Roadshow",
  "date": "2019-10-02",
  "sigh": 2,
  "yo": 2,
  "wokay": 0
}, {
  "site_nm": "gs",
  "date": "2019-10-02",
  "sigh": 3,
  "yo": 3,
  "wokay": 2
}, {
  "site_nm": "TR",
  "date": "2019-10-02",
  "sigh": 4,
  "yo": 3,
  "wokay": 0
}, {
  "site_nm": "cn Highlights",
  "date": "2019-10-03",
  "sigh": 8,
  "yo": 8,
  "wokay": 0
}, {
  "site_nm": "gs Universe",
  "date": "2019-10-02",
  "sigh": 1,
  "yo": 1,
  "wokay": 0
}, {
  "site_nm": "cn en Espa\u00f1ol",
  "date": "2019-10-02",
  "sigh": 6,
  "yo": 6,
  "wokay": 0
}, {
  "site_nm": "gs Trailers",
  "date": "2019-10-02",
  "sigh": 2,
  "yo": 2,
  "wokay": 0
}, {
  "site_nm": "ZD",
  "date": "2019-10-02",
  "sigh": 4,
  "yo": 4,
  "wokay": 1
}, {
  "site_nm": "cn",
  "date": "2019-10-05",
  "sigh": 5,
  "yo": 5,
  "wokay": 1
}, {
  "site_nm": "TV",
  "date": "2019-10-02",
  "sigh": 1,
  "yo": 1,
  "wokay": 0
}, {
  "site_nm": "CH",
  "date": "2019-10-02",
  "sigh": 1,
  "yo": 1,
  "wokay": 0
}, {
  "site_nm": "GB",
  "date": "2019-10-02",
  "sigh": 3,
  "yo": 3,
  "wokay": 3
}, {
  "site_nm": "DLNow",
  "date": "2019-10-02",
  "sigh": 1,
  "yo": 0,
  "wokay": 0
}, {
  "site_nm": "gs News",
  "date": "2019-10-02",
  "sigh": 2,
  "yo": 2,
  "wokay": 0
}];
//sort by site_nm
function compare(a, b) {
  const site_a = a.site_nm.toUpperCase();
  const site_b = b.site_nm.toUpperCase();
  let comparison = 0;
  if (site_a > site_b) {
    comparison = 1;
  } else if (site_a < site_b) {
    comparison = -1;
  }
  return comparison;
}
json = data.sort(compare);
console.log(json.length);
let sites = [...new Set(json.map(({
  site_nm
}) => site_nm))].sort();
let dates = [...new Set(json.map(({
  date
}) => date))].sort();
for (var date = moment(dates[0], "YYYY-MM-DD"); date <= moment(dates[dates.length - 1], "YYYY-MM-DD"); date = date.add(1, 'days')) {
  // console.log(date);
  var dateFormatted = date.format("YYYY-MM-DD");
  console.log(dateFormatted);
  function iterate(item) {
    if (!dates.includes(dateFormatted)) {
      json.push({
        "site_nm": item,
        "date": dateFormatted,
        "sigh": "",
        "yo": "",
        "wokay": ""
      });
    }
  }
}
sites.forEach(iterate);
console.log(json.length);
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.24.0/moment.min.js"></script>

Мои даты увеличиваются, но я не могу добавить их на site_nm. Для каждого сайта я хочу указать отсутствующие даты в объектах. У меня всего 18 разных сайтов, и у меня всего 5 дней, поэтому я хотел бы, чтобы общая длина JSON составляла 18 * 5 = 90. 5 объектов для каждого сайта. Как мне сделать forEach для каждого сайта?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...