PHPCon Poland 2024

CallbackFilterIterator クラス

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

はじめに

クラス概要

class CallbackFilterIterator extends FilterIterator {
/* メソッド */
public __construct(Iterator $iterator, callable $callback)
public accept(): bool
/* 継承したメソッド */
}

コールバックは、三つの引数を受け付けなければなりません。 それぞれ、現在のアイテム、現在のキー、そしてイテレータを表します。

例1 利用可能なコールバック引数

<?php

/**
* CallbackFilterIterator 用のコールバック
*
* @param $current 現在のアイテムの値
* @param $key 現在のアイテムのキー
* @param $iterator フィルタリングするイテレータ
* @return boolean 現在のアイテムを受け付ける場合は TRUE、それ以外の場合は FALSE
*/
function my_callback($current, $key, $iterator) {
// ここにフィルタリングのコードを書きます
}

?>

任意の callable を使うことができます。 関数名を含む文字列、メソッドを表す配列、あるいは無名関数などです。

例2 コールバックの基本例

<?php

$dir
= new FilesystemIterator(__DIR__);

// 大きなファイル ( > 100MB) をフィルタします
function is_large_file($current) {
return
$current->isFile() && $current->getSize() > 104857600;
}
$large_files = new CallbackFilterIterator($dir, 'is_large_file');

// ディレクトリをフィルタします
$files = new CallbackFilterIterator($dir, function ($current, $key, $iterator) {
return
$current->isDir() && ! $iterator->isDot();
});

?>

目次

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
2
asadi dot jabar at outlook dot com
5 years ago
CallbackFilterIterator class didnot implement OuterIterator interface directly

below is the correct hierarchy

CallbackFilterIterator
|__FilterIterator
|___ IteratorIterator
|____ OuterIterator

please fix the documentation
up
1
tunaabutbul[plus]php[at]gmail[dot]com
6 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 ...
}
// .......
?>
To Top