• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

172
Vistas
Typescript/Javascript Contar valores duplicados basados en 2 parámetros

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?

almost 3 years ago · Juan Pablo Isaza
1 Respuestas
Responde la pregunta

0

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);

almost 3 years ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda