Rumah > Artikel > pembangunan bahagian belakang > Bagaimana untuk Mencari Fail secara Rekursif dalam Subfolder dengan PHP: Glob vs. RecursiveDirectoryIterator?
Apabila mengimbas pelayan untuk fail, keperluan sering timbul untuk melanjutkan carian melepasi folder akar untuk memasukkan subfolder dan sub-subfolder. Begini cara untuk mencapainya menggunakan fungsi glob PHP dan RecursiveDirectoryIterator.
Glob menyediakan bentuk carian rekursif terhad dengan fungsi glob(). Walau bagaimanapun, ia tidak mempunyai sokongan untuk pilihan tertentu seperti GLOB_BRACE. Untuk mengatasinya, anda boleh menggunakan fungsi tersuai rglob() yang merentasi struktur direktori secara rekursif dan mengembalikan tatasusunan gabungan fail yang sepadan:
function rglob($pattern, $flags = 0) { $files = glob($pattern, $flags); foreach (glob(dirname($pattern).'/*', GLOB_ONLYDIR|GLOB_NOSORT) as $dir) { $files = array_merge( [], ...[$files, rglob($dir . "/" . basename($pattern), $flags)] ); } return $files; }
Pilihan lain untuk carian rekursif ialah kelas RecursiveDirectoryIterator. Ia menawarkan pendekatan yang lebih mantap dan boleh diperluaskan:
function rsearch($folder, $regPattern) { $dir = new RecursiveDirectoryIterator($folder); $ite = new RecursiveIteratorIterator($dir); $files = new RegexIterator($ite, $regPattern, RegexIterator::GET_MATCH); $fileList = array(); foreach($files as $file) { $fileList = array_merge($fileList, $file); } return $fileList; }
Kedua-dua rglob() dan rsearch() boleh melakukan carian fail rekursif. RecursiveDirectoryIterator menawarkan fleksibiliti tambahan melalui pilihan kebolehlanjutannya. Pilihan antara kedua-duanya bergantung pada keperluan khusus anda dan tahap kawalan yang diingini.
Atas ialah kandungan terperinci Bagaimana untuk Mencari Fail secara Rekursif dalam Subfolder dengan PHP: Glob vs. RecursiveDirectoryIterator?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!