ホームページ  >  記事  >  バックエンド開発  >  2D PHP 配列内の列をグループ化して合計するにはどうすればよいですか?

2D PHP 配列内の列をグループ化して合計するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-10-26 04:06:27551ブラウズ

How to Group and Sum Columns in a 2D PHP Array?

2D 配列内の列のグループ化と合計

このタスクは、各要素が行を表す PHP データ配列を処理することです。各行は、url_id と time_spent の 2 つの列で構成されます。目標は、url_id 列で行をグループ化し、各グループの time_spent 列の値を合計することです。

解決策:

PHP の array_count_values() を使用できます。これを実現する関数:

<code class="php">$ts_by_url = array_count_values(array_column($array, 'url_id'));</code>

array_column() 関数は、入力配列から url_id 列を抽出し、url_id 値の配列を生成します。次に、array_count_values() 関数は、各 url_id 値の出現回数をカウントし、行を効果的にグループ化します。

ただし、このソリューションは、各 url_id の出現回数のみを提供します。各グループ内の time_spent 値を合計するには、アプローチを変更する必要があります。

<code class="php">$ts_by_url = array();
foreach ($array as $data) {
    if (!array_key_exists($data['url_id'], $ts_by_url)) {
        $ts_by_url[$data['url_id']] = 0;
    }
    $ts_by_url[$data['url_id']] += $data['time_spent'];
}</code>

この更新されたアプローチでは、各 url_id の time_spent 値の合計を保持する配列 $ts_by_url を維持します。入力配列を反復処理して、対応する url_id が $ts_by_url にすでに存在するかどうかを各行で確認します。そうでない場合は、値 0 で初期化します。とにかく、$ts_by_url の対応する url_id エントリに time_spent 値を追加します。

このアプローチにより、行を url_id でグループ化し、次の time_spent 値を合計することができます。各グループ。結果の $ts_by_url 配列には、url_id をキーとした目的の合計が含まれます。

以上が2D PHP 配列内の列をグループ化して合計するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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