Tengo dificultades para manipular mis datos para que sean útiles en un gráfico de barras.
Estos son los datos con los que se termina después de mapearlos solo con las propiedades que necesito:
const data = [ { date: "2021-10-10", serialNumber: "4A6211B92417A7DB" }, { date: "2021-10-11", serialNumber: "5B6211B92417A7DB" }, { date: "2021-10-12", serialNumber: "5B6211B92417A7DB" }, { date: "2021-10-12", serialNumber: "4A6211B92417A7DB" }, { date: "2021-10-12", serialNumber: "4A6211B92417A7DB" }, { date: "2021-10-12", serialNumber: "4A6211B92417A7DB" } ];
Lo que quiero tener es lo siguiente: un recuento de los duplicados según la fecha por número de serie . Se vería así:
const solution = [ { serialNumber: "4A6211B92417A7DB", count: 3, date: "2021-10-12", }, { serialNumber: "5B6211B92417A7DB", count: 1, date: "2021-10-12", }, { serialNumber: "5B6211B92417A7DB", count: 1, date: "2021-10-11", }, { serialNumber: "5B6211B92417A7DB", count: 1, date: "2021-10-10", }, ]
Lo que se me ocurrió fue lo siguiente:
array.forEach(function(obj: any) { const key = JSON.stringify(obj.serialNumber) counts[key] = (counts[key] || 0) + 1 });
pero luego solo los cuenta en función de 1 parámetro y también necesito el recuento por fecha. ¿Cómo haces esto?
Puede utilizar un 'grupo por' con una clave compuesta formada por la fecha y el número de serie. Aquí usando un bucle for..of
para acumular en un objeto, creando la clave compuesta usando un literal de plantilla y luego asignando Object.values()
como resultado.
const data = [{ date: '2021-10-10', serialNumber: '4A6211B92417A7DB', }, { date: '2021-10-11', serialNumber: '5B6211B92417A7DB', }, { date: '2021-10-12', serialNumber: '5B6211B92417A7DB', }, { date: '2021-10-12', serialNumber: '4A6211B92417A7DB', }, { date: '2021-10-12', serialNumber: '4A6211B92417A7DB', }, { date: '2021-10-12', serialNumber: '4A6211B92417A7DB', },]; const counts = {}; for (const datum of data) { const k = `${datum.date}_${datum.serialNumber}`; // using OR short circuit (counts[k] || (counts[k] = { ...datum, count: 0 })).count += 1; // alternativley with logical nullish assignment if available //(counts[k] ??= { ...datum, count: 0 }).count += 1; } const result = Object.values(counts); console.log(result);