>웹 프론트엔드 >JS 튜토리얼 >여러 속성을 기준으로 배열의 개체를 효율적으로 그룹화하고 집계하려면 어떻게 해야 합니까?

여러 속성을 기준으로 배열의 개체를 효율적으로 그룹화하고 집계하려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-14 16:06:02597검색

How can I efficiently group and aggregate objects in an array by multiple properties?

여러 속성을 사용하여 배열의 객체를 효율적으로 그룹화 및 집계

이 문서에서는 중요한 작업인 배열 내에서 객체 그룹화에 대해 다룹니다. 여러 속성을 사용하여 해당 값을 집계합니다.

과제

다양한 기준에 따라 배열로 객체를 그룹화하는 것은 난해한 문제가 될 수 있습니다. 기존 솔루션은 여러 키로 개체를 그룹화할 수 있지만 중복 항목을 효과적으로 결합하고 제거하지 못하는 경우가 많습니다. 우리의 목표는 개체를 모양과 색상별로 원활하게 그룹화하고 각각의 '사용된' 값과 '인스턴스' 값을 합산하여 중복을 제거하는 솔루션을 만드는 것입니다.

솔루션

우리의 접근 방식은 도우미 개체와 함께 array.reduce() 메서드를 활용합니다. 배열의 각 객체에 대해 모양과 색상을 연결하여 고유한 키를 구성합니다. 그런 다음 이 키가 도우미 개체에 있는지 확인합니다.

  1. 키가 있으면 도우미에서 해당 개체의 'used' 및 'instances' 값을 증가시키기만 하면 됩니다.
  2. 키가 존재하지 않으면 원본의 복사본으로 새 개체를 만들고 Object.sign()을 사용하여 도우미 개체에 추가합니다. 또한 이 개체를 결과 배열에 푸시합니다.

도우미 개체를 사용하여 모양과 색상의 고유한 조합을 추적함으로써 중복 항목을 제거하는 동시에 개체를 효과적으로 그룹화하고 집계합니다.

var arr = [{"shape":"square","color":"red","used":1,"instances":1},
{"shape":"square","color":"red","used":2,"instances":1},
{"shape":"circle","color":"blue","used":0,"instances":0},
{"shape":"square","color":"blue","used":4,"instances":4},
{"shape":"circle","color":"red","used":1,"instances":1},
{"shape":"circle","color":"red","used":1,"instances":0},
{"shape":"square","color":"blue","used":4,"instances":5},
{"shape":"square","color":"red","used":2,"instances":1}
];

var helper = {};
var result = arr.reduce(function(r, o) {
  var key = o.shape + '-' + o.color;

  if(!helper[key]) {
    helper[key] = Object.assign({}, o); // create a copy of o
    r.push(helper[key]);
  } else {
    helper[key].used += o.used;
    helper[key].instances += o.instances;
  }

  return r;
}, []);

console.log(result);

출력

이 솔루션을 구현함으로써 우리는 원하는 것을 얻습니다. 결과:

[{"shape":"square","color":"red","used":5,"instances":3},
{"shape":"circle","color":"red","used":2,"instances":1},
{"shape":"square","color":"blue","used":11,"instances":9},
{"shape":"circle","color":"blue","used":0,"instances":0}]

이렇게 하면 개체를 모양과 색상별로 효과적으로 그룹화하고 해당 값을 합산하며 중복 항목을 제거합니다.

위 내용은 여러 속성을 기준으로 배열의 개체를 효율적으로 그룹화하고 집계하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.