Rumah >pembangunan bahagian belakang >masalah PHP >Bagaimana untuk mengisih elemen dalam tatasusunan dalam php
Dalam PHP, untuk mengisih tatasusunan 2 dimensi, anda boleh menggunakan fungsi terbina dalam usort()
dan uasort()
untuk mencapainya. Kedua-dua fungsi boleh menyusun elemen dalam tatasusunan, tetapi pelaksanaannya sedikit berbeza. Fungsi
usort()
akan mengisih tatasusunan asal dan mengembalikan nilai Boolean, manakala fungsi uasort()
akan mengisih tatasusunan asal tetapi mengekalkan perkaitan antara pasangan nilai kunci, iaitu, tiada tatasusunan indeks baharu akan diwujudkan. Di bawah ini kami akan memperkenalkan cara menggunakan kedua-dua fungsi ini masing-masing.
usort()
Fungsiusort()
Parameter pertama fungsi ialah tatasusunan yang perlu diisih, dan parameter kedua ialah fungsi perbandingan, yang dilaksanakan dengan menambah tatasusunan kepada tatasusunan yang perlu diisih kedudukan elemen dan mengembalikan nilai Boolean.
//示例数组$students $students = array( array("name" => "张三", "age" => 22), array("name" => "李四", "age" => 20), array("name" => "王五", "age" => 25) ); //比较函数cmp function cmp($a, $b){ if ($a["age"] == $b["age"]) { return 0; } return ($a["age"] < $b["age"]) ? -1 : 1; } //使用usort()排序 usort($students, "cmp"); //输出结果 var_dump($students);
Dalam kod di atas, kami mula-mula mentakrifkan tatasusunan 2 dimensi $pelajar yang mengandungi tiga elemen, setiap elemen mengandungi dua pasangan nilai kunci "nama" dan "umur".
Seterusnya, kami mentakrifkan fungsi perbandingan cmp
, yang menentukan susunan relatif antara elemen dengan membandingkan nilai dua elemen pada pasangan nilai kunci "umur". Jika "umur" dua elemen adalah sama, 0 dikembalikan jika "umur" $a kurang daripada "umur" $b, maka -1 dikembalikan, menunjukkan bahawa $a berada di hadapan $ b; jika tidak, 1 dikembalikan, menunjukkan bahawa $a Selepas $b.
Akhir sekali, kami menggunakan fungsi usort()
untuk mengisih tatasusunan $pelajar mengikut peraturan yang ditakrifkan oleh fungsi cmp
. Daripada output, anda boleh melihat bahawa elemen dalam tatasusunan telah diisih dari kecil ke besar mengikut pasangan nilai kunci "umur".
uasort()
Fungsi Pelaksanaan fungsi uasort()
adalah serupa dengan usort()
, tetapi perbezaannya ialah perkaitan antara pasangan nilai kunci dikekalkan dan tiada tatasusunan indeks baharu dicipta. Oleh itu, ia memerlukan fungsi perbandingan yang lebih kompleks yang bukan sahaja membandingkan saiz elemen tetapi juga mengekalkan perkaitan pasangan nilai kunci.
//示例数组$students $students = array( "stu1" => array("name" => "张三", "age" => 22), "stu2" => array("name" => "李四", "age" => 20), "stu3" => array("name" => "王五", "age" => 25) ); //比较函数cmp function cmp($a, $b){ if ($a["age"] == $b["age"]) { return 0; } return ($a["age"] < $b["age"]) ? -1 : 1; } //使用usort()排序 uasort($students, "cmp"); //输出结果 var_dump($students);
Dalam kod di atas, kami mula-mula mentakrifkan tatasusunan bersekutu 2 dimensi $pelajar yang mengandungi tiga elemen, setiap elemen mengandungi dua pasangan nilai kunci "nama" dan "umur". Perbezaannya ialah di sini kita menggunakan rentetan "stu1", "stu2" dan "stu3" sebagai nilai utama tatasusunan dan bukannya indeks berangka sebelumnya.
mentakrifkan fungsi perbandingan cmp dengan cara yang sama seperti usort()
. Perbezaannya ialah apabila kita memanggil fungsi uasort()
, kita lulus tatasusunan $pelajar dan fungsi perbandingan cmp
sebagai parameter. Fungsi ini mengisih tatasusunan mengikut peraturan cmp
dan hasil yang diisih mengekalkan perhubungan nilai kunci bersama asal.
Akhir sekali, kami mengeluarkan hasil pengisihan melalui fungsi var_dump(). Seperti yang anda lihat, hasil keluaran masih merupakan tatasusunan bersekutu, tetapi elemen telah diisih dari kecil ke besar mengikut pasangan nilai kunci "umur".
Selain usort()
dan uasort()
, PHP juga menyediakan satu siri fungsi pengisihan tatasusunan lain, seperti asort()
, arsort()
, ksort()
, krsort()
, dsb., pembangun boleh Pilih fungsi yang sesuai mengikut keperluan sebenar.
Atas ialah kandungan terperinci Bagaimana untuk mengisih elemen dalam tatasusunan dalam php. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!