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 サイトの他の関連記事を参照してください。