Itérateurs
PHP Manual

La classe CallbackFilterIterator

(PHP 5 >= 5.4.0)

Introduction

Synopsis de la classe

CallbackFilterIterator extends FilterIterator implements Iterator , Traversable , OuterIterator {
/* Méthodes */
public __construct ( Iterator $iterator , callable $callback )
public string accept ( void )
/* Méthodes héritées */
abstract bool FilterIterator::accept ( void )
mixed FilterIterator::current ( void )
mixed FilterIterator::key ( void )
void FilterIterator::next ( void )
void FilterIterator::rewind ( void )
bool FilterIterator::valid ( void )
}

Exemples

La fonction de rappel doit accepter jusqu'à trois arguments : l'élément courant, la clé courante et l'itérateur courant, respectivement.

Exemple #1 Arguments disponibles pour la fonction de rappel

<?php

/**
 * Fonction de rappel pour CallbackFilterIterator
 *
 * @param $current   Valeur de l'élément courant
 * @param $key       Clé de l'élément courant
 * @param $iterator  Itérateur à filtrer
 * @return boolean   TRUE pour accepter l'élément courant, FALSE sinon
 */
function my_callback($current$key$iterator) {
    
// Votre filtre ici
}

?>

N'importe quel callable peut être utilisé ; comme une chaîne de caractères contenant un nom de fonction, un tableau pour une méthode, ou une fonction anonyme.

Exemple #2 Exemples simples de fonction de rappel

<?php

$dir 
= new FilesystemIterator(__DIR__);

// Filtre les gros fichiers ( > 100MB)
function is_large_file($current) {
    return 
$current->isFile() && $current->getSize() > 104857600;
}
$large_files = new CallbackFilterIterator($dir'is_large_file');

// Filtre les dossiers
$files = new CallbackFilterIterator($dir, function ($current$key$iterator) {
    return 
$current->isDir() && ! $iterator->isDot();
});

?>

Sommaire


Itérateurs
PHP Manual