Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk melintasi tatasusunan multidimensi dalam php

Bagaimana untuk melintasi tatasusunan multidimensi dalam php

PHPz
PHPzasal
2023-04-19 11:39:251120semak imbas

Sebagai bahasa pengaturcaraan sebelah pelayan yang biasa digunakan, PHP sering berurusan dengan tatasusunan berbilang dimensi. Apabila menghuraikan dan memanipulasi tatasusunan berbilang dimensi, persoalan biasa ialah cara merentasi pelbagai peringkat tatasusunan ini. Artikel ini akan memperkenalkan cara melintasi tatasusunan berbilang dimensi dalam PHP.

  1. gelung foreach merentasi tatasusunan berbilang dimensi

Dalam PHP, kita boleh menggunakan gelung foreach untuk melintasi tatasusunan. Apabila merentasi tatasusunan berbilang dimensi, kita boleh menyarangkan gelung foreach untuk mengakses setiap peringkat tatasusunan secara bergilir-gilir. Berikut ialah contoh mudah:

$array = array(
    array(1, 2, 3),
    array(4, 5, 6),
    array(7, 8, 9)
);

foreach ($array as $items) {
    foreach ($items as $item) {
        echo $item . ' ';
    }
    echo '<br>';
}

Kod di atas akan mengeluarkan keputusan berikut:

1 2 3 
4 5 6 
7 8 9

Seperti yang anda lihat, kami mula-mula menggunakan gelung foreach untuk melintasi tahap pertama daripada tatasusunan berbilang dimensi, dan kemudian Gunakan gelung foreach bersarang di dalam badan gelung untuk melintasi tahap kedua. Ini akan mengeluarkan keseluruhan tatasusunan multidimensi dalam urutan.

  1. Gunakan fungsi rekursif untuk melintasi tatasusunan berbilang dimensi

Selain menggunakan gelung foreach, kami juga boleh menggunakan fungsi rekursif untuk melintasi tatasusunan berbilang dimensi. Fungsi rekursif merujuk kepada teknik yang memanggil fungsi itu sendiri semasa proses definisi fungsi. Apabila mengakses tatasusunan berbilang dimensi, kita boleh menulis fungsi rekursif yang terus masuk lebih dalam ke setiap peringkat tatasusunan sehingga ia menemui elemen paling dalam. Berikut ialah contoh menggunakan fungsi rekursif untuk melintasi tatasusunan berbilang dimensi:

$array = array(
    'name' => '张三',
    'age' => 18,
    'hobbies' => array(
        'reading',
        'swimming',
        'traveling'
    ),
    'friends' => array(
        array(
            'name' => '李四',
            'age' => 20
        ),
        array(
            'name' => '王五',
            'age' => 22,
            'hobbies' => array(
                'singing',
                'dancing'
            )
        )
    )
);

function traverseArray($arr)
{
    foreach ($arr as $key => $value) {
        if (is_array($value)) {
            traverseArray($value);
        } else {
            echo $key . ' => ' . $value . '<br>';
        }
    }
}

traverseArray($array);

Kod di atas akan mengeluarkan keputusan berikut:

name => 张三 
age => 18 
0 => reading 
1 => swimming 
2 => traveling 
name => 李四 
age => 20 
name => 王五 
age => 22 
0 => singing 
1 => dancing

Seperti yang anda lihat, kita mula-mula mentakrifkan traverseArray Fungsi rekursif, dan gelung foreach digunakan dalam badan fungsi untuk melintasi tatasusunan. Dalam badan gelung, kami menggunakan fungsi is_array untuk mengesan sama ada elemen semasa adalah daripada jenis tatasusunan. Jika ya, panggil fungsi traverseArray secara rekursif untuk meneruskan traversing jika tidak, keluarkan secara langsung pasangan nilai kunci elemen.

Perlu diambil perhatian bahawa fungsi rekursif boleh memanggil dirinya secara tak terhingga, menghasilkan gelung tak terhingga. Untuk mengelakkan ini, kita perlu menambah syarat untuk menamatkan rekursi di dalam badan fungsi. Dalam contoh di atas, kami mengandaikan bahawa semua elemen bukan tatasusunan adalah unsur paling dalam, jadi tidak perlu melintasinya lagi.

  1. Gunakan fungsi array_walk_recursive untuk melintasi tatasusunan berbilang dimensi

Dalam PHP, kita juga boleh menggunakan fungsi array_walk_recursive untuk melintasi tatasusunan berbilang dimensi. Fungsi ini ialah cara untuk melaksanakan fungsi panggil balik secara rekursif pada tatasusunan berbilang dimensi.

Berikut ialah contoh menggunakan fungsi array_walk_recursive untuk melintasi tatasusunan berbilang dimensi:

$array = array(
    'name' => '张三',
    'age' => 18,
    'hobbies' => array(
        'reading',
        'swimming',
        'traveling'
    ),
    'friends' => array(
        array(
            'name' => '李四',
            'age' => 20
        ),
        array(
            'name' => '王五',
            'age' => 22,
            'hobbies' => array(
                'singing',
                'dancing'
            )
        )
    )
);

function output($value, $key)
{
    echo $key . ' => ' . $value . '<br>';
}

array_walk_recursive($array, 'output');

Kod di atas akan mengeluarkan keputusan berikut:

name => 张三 
age => 18 
0 => reading 
1 => swimming 
2 => traveling 
name => 李四 
age => 20 
name => 王五 
age => 22 
0 => singing 
1 => dancing

Kami mentakrifkan fail yang dipanggil output Fungsi output, dan masukkan nama fungsi dalam parameter kedua fungsi array_walk_recursive. Dalam badan fungsi output, kami secara langsung mengeluarkan pasangan nilai kunci elemen semasa.

Perlu diambil perhatian bahawa fungsi array_walk_recursive tidak merentasi tatasusunan berbilang dimensi lapisan demi lapisan. Sebaliknya, ia melakukan traversal mendalam-pertama bagi setiap elemen dalam tatasusunan, secara rekursif melintasi setiap elemen bukan tatasusunan dan kemudian melintasi elemen tatasusunan terdalam. Oleh itu, walaupun fungsi ini mudah, ia mungkin tidak memenuhi keperluan traversal tertentu dalam beberapa kes.

Kesimpulan

Dalam PHP, terdapat banyak cara untuk melintasi tatasusunan berbilang dimensi, yang paling biasa ialah menggunakan gelung foreach dan fungsi rekursif. Walaupun fungsi array_walk_recursive juga menyediakan kaedah traversal pilihan, kesannya mungkin tidak fleksibel seperti dua kaedah lain. Semasa menulis program, kita harus memilih kaedah traversal yang sesuai berdasarkan keperluan tertentu.

Atas ialah kandungan terperinci Bagaimana untuk melintasi tatasusunan multidimensi dalam php. 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