(PHP 5 >= 5.1.2)
RecursiveDirectoryIterator::__construct — Constructs a RecursiveDirectoryIterator
Constructs a RecursiveDirectoryIterator() for the provided path.
The path of the directory to be iterated over.
Flags may be provided which will affect the behavior of some methods. A list of the flags can found under FilesystemIterator predefined constants. They can also be set later with FilesystemIterator::setFlags().
Returns the newly created RecursiveDirectoryIterator.
Throws an UnexpectedValueException if the path cannot be found or is not a directory.
Beispiel #1 RecursiveDirectoryIterator example
<?php
$directory = '/tmp';
$it = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($directory));
while($it->valid()) {
if (!$it->isDot()) {
echo 'SubPathName: ' . $it->getSubPathName() . "\n";
echo 'SubPath: ' . $it->getSubPath() . "\n";
echo 'Key: ' . $it->key() . "\n\n";
}
$it->next();
}
?>
Das oben gezeigte Beispiel erzeugt eine ähnliche Ausgabe wie:
SubPathName: fruit/apple.xml SubPath: fruit Key: /tmp/fruit/apple.xml SubPathName: stuff.xml SubPath: Key: /tmp/stuff.xml SubPathName: veggies/carrot.xml SubPath: veggies Key: /tmp/veggies/carrot.xml
You can use RecursiveDirectoryIterator::FOLLOW_SYMLINK as a flag to the constructor to have RecursiveDirectoryIterator follow symlinks, which it does not do by default.