ホームページ >バックエンド開発 >PHPチュートリアル >配列データを複数の列でグループ化し、グループ内の値を合計する方法

配列データを複数の列でグループ化し、グループ内の値を合計する方法

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-05 13:18:02521ブラウズ

How to Group Array Data by Multiple Columns and Sum Values in Groups?

配列データを複数の列でグループ化し、グループ内の値を合計する

この状況では、2 つの要素に基づいて多次元配列データをグループ化する必要があります。列の値 ('part' と 'type') を計算し、各グループ内の特定の列の値 ('count') を合計します。説明したように入力配列 ($arr1) を指定すると、目的の出力 ($arr2) は、「part」と「type」の各組み合わせの合計カウント値を含むグループ化されたデータを表します。

この結果を達成するには、カスタム関数を利用できます:

<code class="php">function groupByPartAndType($input) {
  $output = Array();

  foreach($input as $value) {
    $output_element = &amp;$output[$value['part'] . "_" . $value['type']];
    $output_element['part'] = $value['part'];
    $output_element['type'] = $value['type'];
    !isset($output_element['count']) &amp;&amp; $output_element['count'] = 0;
    $output_element['count'] += $value['count'];
  }

  return array_values($output);
}</code>

この関数内:

  • グループ化されたデータを保存するために $output 配列が作成されます。
  • $ の各要素入力は反復されます。
  • $output 要素のキーは、'part' 値と 'type' 値を連結することによって作成されます。
  • $output_element の値は、それに応じて割り当てられるか更新されます。
  • 最後に、array_values() を使用して $output 配列の値を新しい配列として返します。

あるいは、両方のデータベースが同じデータベース サーバー上にある場合、グループ化とSQL の GROUP BY 機能を使用すると、合計を効率的に実行できます。

以上が配列データを複数の列でグループ化し、グループ内の値を合計する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。