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

Patricia Arquette
Lepaskan: 2024-11-09 03:26:02
asal
108 orang telah melayarinya

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'],
];
Salin selepas log masuk

Keputusan yang Diingini:

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

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

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!

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
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!