Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana untuk Menghimpun dan Menjumlahkan Data dalam Tatasusunan 2D mengikut Lajur?

Bagaimana untuk Menghimpun dan Menjumlahkan Data dalam Tatasusunan 2D mengikut Lajur?

Patricia Arquette
Patricia Arquetteasal
2024-11-09 03:26:02203semak imbas

How to Group and Sum Data in a 2D Array by Column?

Mengumpul dan Menjumlahkan Data dalam Tatasusunan 2D

Dalam senario ini, anda menyasarkan untuk mengumpulkan baris tatasusunan 2D berdasarkan satu nilai lajur dan kemudian jumlahkan nilai lajur lain dalam setiap lajur kumpulan.

Data Input:

[
    ['quantity' => 5,  'dd' => '01-Nov-2012'],
    ['quantity' => 10, 'dd' => '01-Nov-2012'],
    ['quantity' => 3,  'dd' => '02-Nov-2012'],
    ['quantity' => 4,  'dd' => '03-Nov-2012'],
    ['quantity' => 15, 'dd' => '03-Nov-2012'],
];

Keputusan yang Diingini:

[
    ['quantity' => 15, 'dd' => '01-Nov-2012'],
    ['quantity' => 3,  'dd' => '02-Nov-2012'],
    ['quantity' => 19, 'dd' => '03-Nov-2012'],
];

Pelaksanaan:

Untuk mencapai ini, ikuti ini langkah:

  1. Lelar melalui baris tatasusunan input.
  2. Untuk setiap baris:

    • Semak sama ada tatasusunan berkumpulan mengandungi entri yang diindeks oleh nilai 'dd' baris semasa.
    • Jika tidak, buat entri dengan nilai 'dd' dan 'kuantiti' awal 0.
    • Naikkan nilai 'kuantiti' entri tatasusunan terkumpul dengan 'kuantiti' baris semasa.
  3. Tukar tatasusunan terkumpul menjadi tatasusunan yang diindeks secara berangka menggunakan array_values().

Kod PHP berikut menunjukkan ini proses:

$in = array(array()); // your input
$out = array();
foreach ($in as $row) {
    if (!isset($out[$row['dd']])) {
        $out[$row['dd']] = array(
            'dd' => $row['dd'],
            'quantity' => 0,
        );
    }
    $out[$row['dd']]['quantity'] += $row['quantity'];
}
$out = array_values($out); // make the out array numerically indexed
var_dump($out);

Pendekatan ini mengumpulkan data input dengan berkesan mengikut lajur 'dd' dan menjumlahkan nilai lajur 'kuantiti' untuk setiap kumpulan, menghasilkan output yang diingini.

Atas ialah kandungan terperinci Bagaimana untuk Menghimpun dan Menjumlahkan Data dalam Tatasusunan 2D mengikut Lajur?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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