


Bagaimana untuk menukar tatasusunan satu dimensi dalam php
Tukar kepada tatasusunan dua dimensi?
Dalam pengaturcaraan PHP, kadangkala adalah perlu untuk menukar tatasusunan satu dimensi kepada tatasusunan dua dimensi, supaya pemprosesan dan paparan data boleh menjadi lebih mudah. Sebagai contoh, kumpulkan data dalam tatasusunan satu dimensi mengikut peraturan tertentu dan masukkannya ke dalam tatasusunan dua dimensi untuk memudahkan statistik dan analisis. Artikel ini akan memperkenalkan cara menukar tatasusunan satu dimensi kepada tatasusunan dua dimensi dalam PHP, dan cara mengumpulkan dan mengisih data.
- Gunakan fungsi array_chunk() untuk menukar
PHP menyediakan fungsi yang dipanggil array_chunk(), yang boleh membahagikan array kepada berbilang tatasusunan kecil, setiap kecil Tatasusunan mengandungi bilangan elemen yang ditentukan. Antaranya, parameter $size mewakili bilangan elemen yang terkandung dalam setiap tatasusunan kecil, dan parameter $preserve_keys menentukan sama ada untuk mengekalkan nama kunci tatasusunan asal. Gunakan fungsi ini untuk menukar tatasusunan satu dimensi kepada tatasusunan dua dimensi. Berikut ialah contoh kod:
<?php $original_array = array('a', 'b', 'c', 'd', 'e', 'f'); $chunked_array = array_chunk($original_array, 2); // 将原数组按每2个元素分为一个小数组 print_r($chunked_array); ?>
Keluaran kod di atas adalah seperti berikut:
Array ( [0] => Array ( [0] => a [1] => b ) [1] => Array ( [0] => c [1] => d ) [2] => Array ( [0] => e [1] => f ) )
Melalui fungsi array_chunk(), kami membahagikan tatasusunan asal kepada tiga tatasusunan kecil, setiap satu kecil tatasusunan mengandungi dua elemen. Ini menukar tatasusunan satu dimensi kepada tatasusunan dua dimensi.
- Gunakan untuk gelung untuk menukar
Selain menggunakan fungsi array_chunk(), kita juga boleh menggunakan gelung untuk melengkapkan proses penukaran ini. Berikut ialah contoh kod:
<?php $original_array = array('a', 'b', 'c', 'd', 'e', 'f'); $chunked_array = array(); $chunk_size = 2; // 每个小数组包含元素数量 $chunk_count = ceil(count($original_array) / $chunk_size); // 小数组数量 for ($i = 0; $i < $chunk_count; $i++) { $chunked_array[$i] = array_slice($original_array, $i * $chunk_size, $chunk_size); } print_r($chunked_array); ?>
Keluaran kod di atas adalah sama dengan hasil penggunaan fungsi array_chunk() di atas. Dalam contoh ini, kita mula-mula mengira bilangan tatasusunan kecil, dan kemudian gunakan fungsi for loop dan array_slice() untuk memisahkan tatasusunan asal dan menyimpannya dalam tatasusunan $chunked_array.
- Kumpulkan dan isih data
Selepas menukar tatasusunan satu dimensi kepada tatasusunan dua dimensi, kami boleh mengumpulkan dan mengisih data mengikut keperluan kami sendiri. Berikut ialah contoh kod:
<?php $original_array = array( array('name' => '张三', 'age' => 18, 'gender' => '男'), array('name' => '李四', 'age' => 21, 'gender' => '女'), array('name' => '王五', 'age' => 22, 'gender' => '男'), array('name' => '赵六', 'age' => 19, 'gender' => '女') ); $chunked_array = array_chunk($original_array, 2); // 将原数组按每2个元素分为一个小数组 $sorted_array = array(); foreach ($chunked_array as $chunk) { $sorted_chunk = array(); foreach ($chunk as $item) { $sorted_chunk[(int)$item['age']][] = $item; } ksort($sorted_chunk); $sorted_array[] = $sorted_chunk; } print_r($sorted_array); ?>
Kod di atas mentakrifkan tatasusunan satu dimensi $original_array yang mengandungi empat elemen Setiap elemen ialah tatasusunan bersekutu yang mengandungi tiga pasangan nilai kunci: nama, umur dan jantina. Kami membahagikan tatasusunan asal kepada tatasusunan kecil mengikut setiap dua elemen, dan mengisih elemen dalam tatasusunan kecil mengikut umur Akhirnya, kami mendapat tatasusunan dua dimensi $sorted_array, yang strukturnya adalah seperti berikut:
Array ( [0] => Array ( [18] => Array ( [0] => Array ( [name] => 张三 [age] => 18 [gender] => 男 ) ) [19] => Array ( [0] => Array ( [name] => 赵六 [age] => 19 [gender] => 女 ) ) ) [1] => Array ( [21] => Array ( [0] => Array ( [name] => 李四 [age] => 21 [gender] => 女 ) ) [22] => Array ( [0] => Array ( [name] => 王五 [age] => 22 [gender] => 男 ) ) ) )
Atas ialah kandungan terperinci Bagaimana untuk menukar tatasusunan satu dimensi dalam php. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Artikel ini meneroka deduplikasi array PHP yang cekap. Ia membandingkan fungsi terbina dalam seperti array_unique () dengan pendekatan hashmap tersuai, menonjolkan prestasi perdagangan berdasarkan saiz array dan jenis data. Kaedah optimum bergantung pada profili

Artikel ini meneroka deduplikasi PHP Array menggunakan keunikan utama. Walaupun bukan kaedah penyingkiran pendua langsung, memanfaatkan keunikan utama membolehkan membuat array baru dengan nilai yang unik dengan nilai pemetaan ke kekunci, menimpa duplikat. AP ini

Artikel ini menganalisis PHP Array Deduplication, menonjolkan kemunculan prestasi pendekatan naif (O (N²)). Ia meneroka alternatif yang cekap menggunakan array_unique () dengan fungsi tersuai, splobjectstorage, dan pelaksanaan hashset, mencapai

Butiran artikel ini melaksanakan beratur mesej dalam PHP menggunakan RabbitMQ dan Redis. Ia membandingkan seni bina mereka (AMQP vs dalam memori), ciri-ciri, dan mekanisme kebolehpercayaan (pengesahan, urus niaga, kegigihan). Amalan terbaik untuk reka bentuk, kesilapan

Artikel ini mengkaji piawaian pengekodan PHP semasa dan amalan terbaik, memberi tumpuan kepada cadangan PSR (PSR-1, PSR-2, PSR-4, PSR-12). Ia menekankan peningkatan kebolehbacaan dan kebolehkerjaan kod melalui gaya yang konsisten, penamaan bermakna, dan EFF

Artikel ini meneroka mengoptimumkan deduplikasi array PHP untuk dataset yang besar. Ia mengkaji teknik-teknik seperti array_unique (), array_flip (), splobjectstorage, dan pra-sorting, membandingkan kecekapan mereka. Untuk dataset besar -besaran, ia mencadangkan pemotongan, pangkalan data

Butiran artikel ini memasang dan menyelesaikan masalah PHP, memberi tumpuan kepada PECL. Ia meliputi langkah pemasangan (mencari, memuat turun/menyusun, membolehkan, memulakan semula pelayan), teknik penyelesaian masalah (memeriksa log, mengesahkan pemasangan,

Artikel ini menerangkan API Refleksi PHP, membolehkan pemeriksaan runtime dan manipulasi kelas, kaedah, dan sifat. IT memperincikan kes penggunaan biasa (penjanaan dokumentasi, ORM, suntikan pergantungan) dan memberi amaran terhadap prestasi overhea
