Shows us all files and catalogues in directory except "." and "..".
<?php
foreach (new DirectoryIterator('../moodle') as $fileInfo) {
if($fileInfo->isDot()) continue;
echo $fileInfo->getFilename() . "<br>\n";
}
?>
DirectoryIterator クラス
導入
DirectoryIterator クラスは、 ファイルシステムのディレクトリを閲覧するためのシンプルなインターフェイスです。
クラス概要
目次
- DirectoryIterator::__construct — パスから新規ディレクトリイテレータを生成する
- DirectoryIterator::current — 現在の DirectoryIterator アイテムを返す
- DirectoryIterator::getATime — 現在の DirectoryIterator アイテムの最終アクセス時刻を取得する
- DirectoryIterator::getBasename — Get base name of current DirectoryIterator item.
- DirectoryIterator::getCTime — 現在の DirectoryIterator アイテムの inode 修正時刻を取得する
- DirectoryIterator::getFilename — 現在の DirectoryIterator アイテムのファイル名を返す
- DirectoryIterator::getGroup — 現在の DirectoryIterator アイテムのグループを取得する
- DirectoryIterator::getInode — 現在の DirectoryIterator アイテムの inode を取得する
- DirectoryIterator::getMTime — 現在の DirectoryIterator アイテムの最終修正時刻を取得する
- DirectoryIterator::getOwner — 現在の DirectoryIterator アイテムの所有者を取得する
- DirectoryIterator::getPath — 現在の Iterator アイテムのパスをファイル名抜きで返す
- DirectoryIterator::getPathname — 現在の DirectoryIterator アイテムのパスとファイル名を返す
- DirectoryIterator::getPerms — 現在の DirectoryIterator アイテムのパーミッションを取得する
- DirectoryIterator::getSize — 現在の DirectoryIterator アイテムのサイズを取得する
- DirectoryIterator::getType — 現在の DirectoryIterator アイテムのタイプを判定する
- DirectoryIterator::isDir — 現在の DirectoryIterator アイテムがディレクトリであるかどうかを調べる
- DirectoryIterator::isDot — 現在の DirectoryIterator アイテムが '.' もしくは '..' であるかどうかを調べる
- DirectoryIterator::isExecutable — 現在の DirectoryIterator アイテムが実行可能であるかどうかを調べる
- DirectoryIterator::isFile — 現在の DirectoryIterator アイテムが通常のファイルであるかどうかを調べる
- DirectoryIterator::isLink — 現在の DirectoryIterator アイテムがシンボリックリンクであるかどうかを調べる
- DirectoryIterator::isReadable — 現在の DirectoryIterator アイテムが読込可能であるかどうかを調べる
- DirectoryIterator::isWritable — 現在の DirectoryIterator アイテムが書き込み可能であるかどうかを調べる
- DirectoryIterator::key — 現在の DirectoryIterator アイテムのキーを返す
- DirectoryIterator::next — 次の DirectoryIterator アイテムに移動する
- DirectoryIterator::rewind — DirectoryIterator を最初に巻き戻す
- DirectoryIterator::seek — Seek to a DirectoryIterator item
- DirectoryIterator::__toString — Get file name as a string
- DirectoryIterator::valid — 現在の DirectoryIterator の位置が有効なファイルであるかどうかチェックする
DirectoryIterator
krystianmularczyk at gmail dot com
25-Jan-2009 11:31
25-Jan-2009 11:31
David Lanstein
21-Jan-2009 08:50
21-Jan-2009 08:50
DirectoryIterator::getBasename() has been also been available since 5.2.2, according to the changelog (not documented yet). It takes a parameter $suffix, and is useful if, for instance, you use a naming convention for your files (e.g. ClassName.php).
The following code uses this to add recursively All*Tests.php in any subdirectory off of tests/, basically, suites of suites.
<?php
// PHPUnit boilerplate code goes here
class AllTests {
public static function main() {
$parameters = array('verbose' => true);
PHPUnit_TextUI_TestRunner::run(self::suite(), $parameters);
}
public static function suite() {
$suite = new PHPUnit_Framework_TestSuite('AllMyTests'); // this must be something different than the class name, per PHPUnit
$it = new AllTestsFilterIterator(
new RecursiveIteratorIterator(
new RecursiveDirectoryIterator(dirname(__FILE__) . '/tests')));
for ($it->rewind(); $it->valid(); $it->next()) {
require_once($it->current());
$className = $it->current()->getBasename('.php');
$suite->addTest($className::suite());
}
return $suite;
}
}
?>
Also, the AllTestsFilterIterator above extends FilterIterator, and contains one method, accept():
<?php
class AllTestsFilterIterator extends FilterIterator {
public function accept() {
if (preg_match('/All.*Tests\.php/', $this->current())) {
return true;
} else {
return false;
}
}
}
?>
Mark van Straten
09-Jul-2008 02:56
09-Jul-2008 02:56
Implements Iterator so you can foreach() over the content of the given directory
