ホームページ > ウェブフロントエンド > jsチュートリアル > 一致するキーを持つ JavaScript オブジェクトを効率的にマージし、それらの値を合計する方法

一致するキーを持つ JavaScript オブジェクトを効率的にマージし、それらの値を合計する方法

Linda Hamilton
リリース: 2024-12-08 05:51:09
オリジナル
328 人が閲覧しました

How to Efficiently Merge JavaScript Objects with Matching Keys and Sum Their Values?

JavaScript 配列内の一致するプロパティを持つオブジェクトのマージ

次のオブジェクトの配列を考えてみましょう:

objArr = [
    {key:"Mon Sep 23 2013 00:00:00 GMT-0400", val:42},
    {key:"Mon Sep 24 2013 00:00:00 GMT-0400", val:78},
    {key:"Mon Sep 25 2013 00:00:00 GMT-0400", val:23},
    {key:"Mon Sep 23 2013 00:00:00 GMT-0400", val:54}, // <- duplicate key
]
ログイン後にコピー

私たちの目標は、重複したキーとそれぞれの値を合計すると、次のようになります。

reducedObjArr = [
    {key:"Mon Sep 23 2013 00:00:00 GMT-0400", val:96},
    {key:"Mon Sep 24 2013 00:00:00 GMT-0400", val:78},
    {key:"Mon Sep 25 2013 00:00:00 GMT-0400", val:23}
]
ログイン後にコピー

最初の試行には値の反復とプッシュが含まれる可能性がありますが、より効率的なアプローチには JavaScript の組み込み関数の活用が含まれます。

// Use a Map to count values with the same key
const counts = objArr.reduce((prev, curr) => {
  let count = prev.get(curr.key) || 0;
  prev.set(curr.key, curr.val + count);
  return prev;
}, new Map());

// Convert the Map back to an array of objects
const reducedObjArr = [...counts].map(([key, value]) => {
  return {key, value};
});
ログイン後にコピー

このメソッドは、キーが重複したキー値を表し、値がそれらの合計を表す Map に配列を縮小します。 。その後、マップは読みやすくするためにオブジェクトの配列に変換されます。

以上が一致するキーを持つ JavaScript オブジェクトを効率的にマージし、それらの値を合計する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート