Rumah > pembangunan bahagian belakang > tutorial php > Bagaimanakah anda mengumpulkan tatasusunan berbilang dimensi dengan dua lajur dan nilai jumlah untuk setiap kumpulan?

Bagaimanakah anda mengumpulkan tatasusunan berbilang dimensi dengan dua lajur dan nilai jumlah untuk setiap kumpulan?

Mary-Kate Olsen
Lepaskan: 2024-11-06 01:16:02
asal
836 orang telah melayarinya

How do you group a multidimensional array by two columns and sum values for each group?

Mengumpulkan Data Tatasusunan Berbilang Dimensi mengikut Dua Lajur dan Menjumlahkan Nilai untuk Setiap Kumpulan

Pertimbangkan tatasusunan yang dibuat dengan menggabungkan hasil daripada dua pertanyaan pangkalan data yang berasingan, menyerupai yang berikut:

$arr1 = [
    ['part' => '1', 'address' => 'aaa', 'type' => '1', 'count' => 5],
    ['part' => '1', 'address' => 'bbb', 'type' => '1', 'count' => 5],
    ['part' => '1', 'address' => 'ccc', 'type' => '1', 'count' => 5],
    ['part' => '2', 'address' => 'aaa', 'type' => '1', 'count' => 5],
    ['part' => '2', 'address' => 'bbb', 'type' => '1', 'count' => 5],
    ['part' => '2', 'address' => 'ccc', 'type' => '2', 'count' => 5]
];
Salin selepas log masuk

Matlamatnya adalah untuk mengumpulkan tatasusunan ini mengikut lajur 'bahagian' dan 'taip' dan mengira jumlah nilai 'kira' bagi setiap kumpulan.

Untuk mencapai ini, kita boleh memanfaatkan fungsi berikut:

<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>
Salin selepas log masuk

Fungsi ini berulang melalui tatasusunan input dan mengisi tatasusunan output dengan elemen yang dikunci oleh gabungan nilai 'bahagian' dan 'jenis'. Untuk setiap elemen output, ia menetapkan medan 'bahagian', 'jenis' dan 'kira' dengan sewajarnya, memastikan medan 'kira' dimulakan kepada sifar jika belum ditetapkan. Fungsi ini mengembalikan tatasusunan nilai daripada tatasusunan output.

Dengan menggunakan fungsi ini pada $arr1, kami memperoleh hasil yang diingini:

$arr2 = [
    ['part' => '1', 'type' => '1', 'count' => 15],
    ['part' => '2', 'type' => '1', 'count' => 10],
    ['part' => '2', 'type' => '2', 'count' => 5]
];
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimanakah anda mengumpulkan tatasusunan berbilang dimensi dengan dua lajur dan nilai jumlah untuk setiap kumpulan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan