有多个选项可用,您可以使用它们以一种或另一种方式对迭代器进行排序。最好的选择很大程度上取决于您希望如何操作迭代器内容、您想从迭代器中得到什么以及您真正想要/需要多少或多少迭代器。
方法会有所不同;使用诸如SplHeap
(或Min
,Max
品种)之类的类,SplPriorityQueue
(可能用于文件大小之类的东西)或者只是将您的迭代器包装在ArrayObject
可以对其自己的内容进行排序的东西中。
我将使用一个SplHeap
作为示例。由于您想按字母顺序排列整个内容,RecursiveDirectoryIterator
因此可以使用以下内容:
class ExampleSortedIterator extends SplHeap
{
public function __construct(Iterator $iterator)
{
foreach ($iterator as $item) {
$this->insert($item);
}
}
public function compare($b,$a)
{
return strcmp($a->getRealpath(), $b->getRealpath());
}
}
$dit = new RecursiveDirectoryIterator("./path/to/files");
$rit = new RecursiveIteratorIterator($dit);
$sit = new ExampleSortedIterator($rit);
foreach ($sit as $file) {
echo $file->getPathname() . PHP_EOL;
}
排序顺序是字母顺序,混合文件和文件夹:
./apple
./apple/alpha.txt
./apple/bravo.txt
./apple/charlie.txt
./artichoke.txt
./banana
./banana/aardvark.txt
./banana/bat.txt
./banana/cat.txt
./beans.txt
./carrot.txt
./cherry
./cherry/amy.txt
./cherry/brian.txt
./cherry/charlie.txt
./damson
./damson/xray.txt
./damson/yacht.txt
./damson/zebra.txt
./duck.txt