Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana untuk mengumpulkan Array PHP 2D ke dalam Array 3D mengikut Nama Mesin?
Cara Menukar Tatasusunan 2D kepada Tatasusunan 3D dalam PHP
Anda mempunyai tatasusunan 2D sedia ada yang mengandungi maklumat kerja untuk mesin yang berbeza. Tugasnya adalah untuk menukar tatasusunan ini kepada tatasusunan 3D, dikumpulkan mengikut nama mesin.
Output yang diingini ialah tatasusunan 3D dengan kuncinya ialah nama mesin dan setiap nama mesin mengandungi tatasusunan rekod kerja. Rekod kerja termasuk medan berikut:
Job_Name Quantity Start_Date Completion_Date Labor
Penyelesaian Kod PHP:
Untuk menukar tatasusunan 2D kepada tatasusunan 3D, anda boleh menggunakan kod PHP berikut :
$result = []; foreach ($MainArray as $record) { $result[$record['Machine_Name']][] = $record; }
Penjelasan:
The foreach gelung berulang melalui setiap rekod dalam $MainArray. Untuk setiap rekod, ia menyemak medan Machine_Name dan menambah rekod pada tatasusunan mesin yang sepadan dalam tatasusunan $result.
Jika nama mesin tidak wujud sebagai kunci dalam tatasusunan $result, ia dicipta dan rekod itu ditambahkan pada tatasusunan di bawah kunci itu.
Contoh:
Diberi yang berikut $MainArray:
[0] => [ 'Job_Name' => 'WXYZ', 'Quantity' => 1000, 'Machine_Name' => 'Machine1', 'Start_Date' => '2014-07-30 00:00:00', 'Completion_Date' => '2014-08-02 00:00:00', 'Labor' => 4 ] [1] => [ 'Job_Name' => 'ABCD', 'Quantity' => 1500, 'Machine_Name' => 'Machine2', 'Start_Date' => '2014-08-08 00:00:00', 'Completion_Date' => '2014-08-14 00:00:00', 'Labor' => 2 ] [2] => [ 'Job_Name' => 'BCDA', 'Quantity' => 1200, 'Machine_Name' => 'Machine1', 'Start_Date' => '2014-08-02 00:00:00', 'Completion_Date' => '2014-08-07 00:00:00', 'Labor' => 1 ]
Output tatasusunan $result ialah:
[Machine1] => [ [ 'Job_Name' => 'WXYZ', 'Quantity' => 1000, 'Start_Date' => '2014-07-30 00:00:00', 'Completion_Date' => '2014-08-02 00:00:00', 'Labor' => 4 ], [ 'Job_Name' => 'BCDA', 'Quantity' => 1200, 'Start_Date' => '2014-08-02 00:00:00', 'Completion_Date' => '2014-08-07 00:00:00', 'Labor' => 1 ] ] [Machine2] => [ [ 'Job_Name' => 'ABCD', 'Quantity' => 1500, 'Start_Date' => '2014-08-08 00:00:00', 'Completion_Date' => '2014-08-14 00:00:00', 'Labor' => 2 ] ]
Susun atur 3D baharu ini boleh digunakan untuk mengakses rekod kerja yang dikumpulkan mengikut nama mesin.
Atas ialah kandungan terperinci Bagaimana untuk mengumpulkan Array PHP 2D ke dalam Array 3D mengikut Nama Mesin?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!