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::__construct — パスから新規ディレクトリイテレータを生成する
- DirectoryIterator::current — これ自身を返す (Iterator インターフェースに必要)
- DirectoryIterator::getATime — ファイルの最終アクセス時刻を取得する
- DirectoryIterator::getCTime — ファイルの inode 修正時刻を取得する
- DirectoryIterator::getFilename — 現在のディレクトリエントリのファイル名を返す
- DirectoryIterator::getGroup — ファイルのグループを取得する
- DirectoryIterator::getInode — ファイルの inode を取得する
- DirectoryIterator::getMTime — ファイルの最終修正時刻を取得する
- DirectoryIterator::getOwner — ファイルの所有者を取得する
- DirectoryIterator::getPath — ディレクトリパスを返す
- DirectoryIterator::getPathname — 現在のディレクトリエントリのパスとファイル名を返す
- DirectoryIterator::getPerms — ファイルのパーミッションを取得する
- DirectoryIterator::getSize — ファイルサイズを取得する
- DirectoryIterator::getType — ファイルタイプを取得する
- DirectoryIterator::isDir — ファイルがディレクトリであれば true を返す
- DirectoryIterator::isDot — 現在のエントリが '.' もしくは '..' の場合 true を返す
- DirectoryIterator::isExecutable — ファイルが実行可能な場合 true を返す
- DirectoryIterator::isFile — ファイルが通常のファイルの場合 true を返す
- DirectoryIterator::isLink — ファイルがシンボリックリンクの場合 true を返す
- DirectoryIterator::isReadable — ファイルが読込可能であれば true を返す
- DirectoryIterator::isWritable — ファイルが書き込み可能であれば true を返す
- DirectoryIterator::key — 現在のディレクトリエントリを返す
- DirectoryIterator::next — 次のエントリに移動する
- DirectoryIterator::rewind — ディレクトリを最初に巻き戻す
- DirectoryIterator::valid — ディレクトリがまだエントリを持っているかどうかチェックする
DirectoryIterator
krystianmularczyk at gmail dot com
25-Jan-2009 01:31
25-Jan-2009 01:31
David Lanstein
21-Jan-2009 10:50
21-Jan-2009 10: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 05:56
09-Jul-2008 05:56
Implements Iterator so you can foreach() over the content of the given directory
