PHP5中增加了Iterator,一組有助于導(dǎo)航和處理等級(jí)數(shù)據(jù)結(jié)構(gòu)的現(xiàn)成接口,這是PHP5最有趣的新特性之一。
這些Iterator顯著減少了處理XML文檔樹或文件集合所需的代碼。PHP5中使用大量Iterator,包括ArrayIterator、 CachingIterator、LimitIterator、RecursiveIterator、SimpleXMLIterator和 DirectoryIterator。
通過DirectoryIterator可以迅速有效地對(duì)目錄中的文件進(jìn)行處理。在編碼過程中稍微增加一些創(chuàng)造力,DirectoryIterator還可用于遞歸處理嵌套式目錄樹。這兩個(gè)任務(wù)只需使用幾行代碼就可以完成,比“標(biāo)準(zhǔn)”處理方法有了顯著提高。
首先我們從簡(jiǎn)單的任務(wù)著手:處理一個(gè)單級(jí)目錄。輸入(或復(fù)制)以下代碼(列表A),修改目錄路徑以反映當(dāng)?shù)嘏渲茫?/p>
列表A
<?php
it = new DirectoryIterator("/tmp/mystuff");
foreach(it as file) {
if (!it->isDot()) {
echo file . "n";
}
}
?>
在瀏覽器中查看這段代碼的輸出結(jié)果,你會(huì)在指定目錄中看到一個(gè)文件列表。這一切是如何發(fā)生的呢?DirectoryIterator提供一個(gè)預(yù)先確 定的接口來重述一個(gè)目錄的內(nèi)容;示例目標(biāo)目錄的位置后,就可以把它當(dāng)作一個(gè)標(biāo)準(zhǔn)的PHP數(shù)組來處理,每個(gè)元素代表目錄中的一個(gè)文件。注意它使用isDot ()方法分別過濾掉“.”和“..”目錄。
遞歸處理一個(gè)嵌套式目錄樹幾乎同樣簡(jiǎn)單。在這種情況下,DirectoryIterator需要檢查它在單級(jí)目錄中遇到的每一個(gè)對(duì)象,確定其是一個(gè)文件還是目錄。如果是一個(gè)目錄,就更深入一級(jí)檢驗(yàn)下一級(jí)的內(nèi)容。這聽起來似乎相當(dāng)復(fù)雜,在過去一般都需要15行以上的代碼。
但是,使用PHP5,你只需要兩個(gè)新的Iterator:RecursiveIterator和RecursiveIteratorIterator,它們組合了所有上述功能。見列表B:
列表B
<?php
it = new RecursiveDirectoryIterator("/tmp");
foreach(new RecursiveIteratorIterator(it) as file) {
echo file . "n";
}
?>
這時(shí),輸入結(jié)果將列出起始目錄下的所有文件和目錄。不必說,如果需要處理某個(gè)特定目錄級(jí)下的所有文件——例如,遞歸壓縮一個(gè)目錄樹;或修改一系列嵌套文件的組/所有者許可時(shí)——使用這種遞歸內(nèi)置接口就非常方便。
打印圖形目錄樹是目錄遞歸的一個(gè)常見應(yīng)用。利用Iterator處理這個(gè)任務(wù)十分簡(jiǎn)單,因?yàn)镮terator類文檔中包含一個(gè)專門為這個(gè)應(yīng)用而編寫 的實(shí)例類。DirectoryTreeIterator(感謝Marcus Boerger)為前面討論的RecursiveIteratorIterator提供了其它改進(jìn),特別是在樹結(jié)構(gòu)中代表深度和位置的ASCII標(biāo)記。
列表C說明了DirectoryTreeIterator的用法。
列表C
<?php
it = new DirectoryTreeIterator("/tmp/cookbook/");
foreach(it as path) {
echo path . "n";
}
?>
以下是你看到的一部分輸出結(jié)果:
|-ch01
| |-recipe01
| | |-example01.php
| | -example02.php
| |-recipe02
| | |-example01.php
| | -example02.php
| |-recipe03
| | -example01.php
...
為更好了解這些DirectoryIterator的價(jià)值,嘗試用標(biāo)準(zhǔn)的文件和目錄函數(shù)對(duì)本教程中說明的三個(gè)應(yīng)用編碼。
新聞熱點(diǎn)
疑難解答