PHP 8.1.0 Alpha 1 available for testing

La clase FilesystemIterator

(PHP 5 >= 5.3.0, PHP 7, PHP 8)


El iterador Filesystem

Sinopsis de la Clase

FilesystemIterator extends DirectoryIterator implements SeekableIterator {
/* Constantes */
const integer CURRENT_AS_PATHNAME = 32 ;
const integer CURRENT_AS_FILEINFO = 0 ;
const integer CURRENT_AS_SELF = 16 ;
const integer CURRENT_MODE_MASK = 240 ;
const integer KEY_AS_PATHNAME = 0 ;
const integer KEY_AS_FILENAME = 256 ;
const integer FOLLOW_SYMLINKS = 512 ;
const integer KEY_MODE_MASK = 3840 ;
const integer NEW_CURRENT_AND_KEY = 256 ;
const integer SKIP_DOTS = 4096 ;
const integer UNIX_PATHS = 8192 ;
/* Métodos */
public __construct(string $path, int $flags = FilesystemIterator::KEY_AS_PATHNAME | FilesystemIterator::CURRENT_AS_FILEINFO | FilesystemIterator::SKIP_DOTS)
public current(): mixed
public getFlags(): int
public key(): string
public next(): void
public rewind(): void
public setFlags(int $flags = ?): void
/* Métodos heredados */
public DirectoryIterator::getBasename( string $suffix = ?): string
public DirectoryIterator::key(): string
public DirectoryIterator::seek(int $position): void

Constantes predefinidas


Hace que FilesystemIterator::current() devuelva el nombre de la ruta.


Hace que FilesystemIterator::current() devuelva una instancia de SplFileInfo .


Hace que FilesystemIterator::current() devuelva $this (el objeto FilesystemIterator).


Enmascara FilesystemIterator::current()


Hace que FilesystemIterator::key() devuelva el nombre de la ruta.


Hace que FilesystemIterator::key() devuelva el nombre de fichero.

Hace que RecursiveDirectoryIterator::hasChildren() siga enlaces simbólicos.


Enmascara FilesystemIterator::key()


Igual que FilesystemIterator::KEY_AS_FILENAME | FilesystemIterator::CURRENT_AS_FILEINFO.


Ignora los ficheros punto (. y ..).


Hace que las rutas usen la barra hacia adelante del estilo Unix independientemente de la predeterminada del sistema. Observe que la ruta path pasada al constructor no se modifica.

Historial de cambios

Versión Descripción
5.3.1 Añadido FilesystemIterator::FOLLOW_SYMLINKS

Tabla de contenidos

add a note add a note

User Contributed Notes 3 notes

paul at paulgarvin dot net
7 years ago
You may be wondering, like I did, what is the difference between this class and DirectoryIterator?

When you iteterate using DirectoryIterator each "value" returned is the same DirectoryIterator object. The internal state is changed so when you call isDir(), getPathname(), etc the correct information is returned. If you were to ask for a key when iterating you will get an integer index value.

FilesystemIterator (and RecursiveDirectoryIterator) on the other hand returns a new, different SplFileInfo object for each iteration step. The key is the full pathname of the file. This is by default. You can change what is returned for the key or value using the "flags" arguement to the constructor.
thedilab at gmail dot com
5 years ago
DirectoryIterator returns virtual directories "." and ".." in a loop.
But FilesystemIterator ignores them.
ohcc at 163 dot com
1 year ago
It's impossible to return dots (. and ..) by FilesystemIterator.
To Top