PHP Conference Japan 2024

La classe CallbackFilterIterator

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

Introduction

Synopsis de la classe

class CallbackFilterIterator extends FilterIterator {
/* Méthodes */
public __construct(Iterator $iterator, callable $callback)
public accept(): bool
/* Méthodes héritées */
}

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

add a note

User Contributed Notes 3 notes

up
10
dave1010 at gmail dot com
12 years ago
Implementation for PHP < 5.4:

<?php
if (!class_exists('CallbackFilterIterator')) {
class
CallbackFilterIterator extends FilterIterator {
protected
$callback;

// "Closure" type hint should be "callable" in PHP 5.4
public function __construct(Iterator $iterator, Closure $callback = null) {
$this->callback = $callback;
parent::__construct($iterator);
}

public function
accept() {
return
call_user_func(
$this->callback,
$this->current(),
$this->key(),
$this->getInnerIterator()
);
}
}
}

?>
up
1
tunaabutbul[plus]php[at]gmail[dot]com
7 years ago
i PHP 7 you can use Anonymous classes to get the same results.

<?php

class MyIterator implements Iterator
{
/**
* @var \Iterator
*/
protected $next;

/**
* Collection constructor.
*
* @param \Iterator $next
*/
public function __construct(Iterator $next)
{
$this->next = $next;
}

/**
* @param callable $callback
*
* @return static
*/
public function filter(callable $callback = null)
{
return new static(new class(
$this, $callback) extends FilterIterator
{
protected
$callback;

public function
__construct(\Iterator $iterator, callable $callback = null)
{
parent::__construct($iterator);

$this->callback = $callback ?: function($current) {
return ! empty(
$current);
};;
}

public function
accept()
{
return
call_user_func($this->callback, parent::accept());
}
});
}
// Iterator methods ...
}
// .......
?>
up
1
asadi dot jabar at outlook dot com
6 years ago
CallbackFilterIterator class didnot implement OuterIterator interface directly

below is the correct hierarchy

CallbackFilterIterator
|__FilterIterator
|___ IteratorIterator
|____ OuterIterator

please fix the documentation
To Top