SPL 是 PHP 標準庫,用於解決典型問題的一組接口與類的集合。javascript
官方文檔:php.net/manual/zh/c…php
類摘要:java
FilesystemIterator extends DirectoryIterator implements SeekableIterator {
/* 常量 */
const integer CURRENT_AS_PATHNAME = 32 ;
const integer CURRENT_AS_FILEINFO = 0 ;
const integer CURRENT_AS_SELF = 16 ;
const integer CURRENT_MODE_MASK = 240 ;
const integer KEY_AS_PATHNAME = 0 ;
const integer KEY_AS_FILENAME = 256 ;
const integer FOLLOW_SYMLINKS = 512 ;
const integer KEY_MODE_MASK = 3840 ;
const integer NEW_CURRENT_AND_KEY = 256 ;
const integer SKIP_DOTS = 4096 ;
const integer UNIX_PATHS = 8192 ;
/* 方法 */
public __construct ( string $path [, int $flags = FilesystemIterator::KEY_AS_PATHNAME | FilesystemIterator::CURRENT_AS_FILEINFO | FilesystemIterator::SKIP_DOTS ] )
public mixed current ( void )
public int getFlags ( void )
public string key ( void )
public void next ( void )
public void rewind ( void )
public void setFlags ([ int $flags ] )
/* 繼承的方法 */
public DirectoryIterator DirectoryIterator::current ( void )
public int DirectoryIterator::getATime ( void )
public string DirectoryIterator::getBasename ([ string $suffix ] )
public int DirectoryIterator::getCTime ( void )
public string DirectoryIterator::getExtension ( void )
public string DirectoryIterator::getFilename ( void )
public int DirectoryIterator::getGroup ( void )
public int DirectoryIterator::getInode ( void )
public int DirectoryIterator::getMTime ( void )
public int DirectoryIterator::getOwner ( void )
public string DirectoryIterator::getPath ( void )
public string DirectoryIterator::getPathname ( void )
public int DirectoryIterator::getPerms ( void )
public int DirectoryIterator::getSize ( void )
public string DirectoryIterator::getType ( void )
public bool DirectoryIterator::isDir ( void )
public bool DirectoryIterator::isDot ( void )
public bool DirectoryIterator::isExecutable ( void )
public bool DirectoryIterator::isFile ( void )
public bool DirectoryIterator::isLink ( void )
public bool DirectoryIterator::isReadable ( void )
public bool DirectoryIterator::isWritable ( void )
public string DirectoryIterator::key ( void )
public void DirectoryIterator::next ( void )
public void DirectoryIterator::rewind ( void )
public void DirectoryIterator::seek ( int $position )
public string DirectoryIterator::__toString ( void )
public bool DirectoryIterator::valid ( void )
}複製代碼
使用這個迭代器的方法很簡單,實例化的時候傳入的是目錄路徑,這個迭代器繼承自 DirectoryIterator 迭代器,而 DirectoryIterator 迭代器又繼承自 SplFileInfo 類,這個類咱們後面介紹。node
$fSI = new FileSystemIterator('.');
/** @var FileSystemIterator $fInfo */
// 模擬 windows dir
foreach ($fSI as $fInfo) {
printf("%8s%8s%8s %8s\n",
date("Y-m-d H:i:s", $fInfo->getMtime()),
$fInfo->isDir() ? '<DIR>' : '',
number_format($fInfo->getSize()),
$fInfo->getFileName()
);
}
// 模擬 linux ls
foreach ($fSI as $fInfo) {
printf("%8s ",
$fInfo->getFileName()
);
}複製代碼
以上代碼模擬了 windows 的 dir 和 linux 的 ls 功能。還有許多功能可使用,看一下官方文檔裏的方法列表就知道了,都是比較語義化的方法命名,好比 isFile 就是判斷一個文件是否是文件, getMTime 是獲取文件的修改時間。linux
官方文檔:php.net/manual/zh/c…windows
SplFileInfo 這個類能夠用來獲取文件的基本信息,如修改時間,大小。函數
SplFileObject 這個類操做文件的內容,如讀取、寫入。學習
類摘要spa
SplFileInfo {
/* 方法 */
public __construct ( string $file_name )
public int getATime ( void )
public string getBasename ([ string $suffix ] )
public int getCTime ( void )
public string getExtension ( void )
public SplFileInfo getFileInfo ([ string $class_name ] )
public string getFilename ( void )
public int getGroup ( void )
public int getInode ( void )
public string getLinkTarget ( void )
public int getMTime ( void )
public int getOwner ( void )
public string getPath ( void )
public SplFileInfo getPathInfo ([ string $class_name ] )
public string getPathname ( void )
public int getPerms ( void )
public string getRealPath ( void )
public int getSize ( void )
public string getType ( void )
public bool isDir ( void )
public bool isExecutable ( void )
public bool isFile ( void )
public bool isLink ( void )
public bool isReadable ( void )
public bool isWritable ( void )
public SplFileObject openFile ([ string $open_mode = "r" [, bool $use_include_path = false [, resource $context = NULL ]]] )
public void setFileClass ([ string $class_name = "SplFileObject" ] )
public void setInfoClass ([ string $class_name = "SplFileInfo" ] )
public void __toString ( void )
}複製代碼
$file = new SplFileInfo('README.md');
echo 'File is created at ' . date('Y-m-d H:i:s', $file->getCTime()) . PHP_EOL;
echo 'File is modified at ' . date('Y-m-d H:i:s', $file->getMTime()) . PHP_EOL;
echo 'File size is ' . $file->getSize() . ' bytes' . PHP_EOL;
// openFile 方法返回的 SplFileObject 對象
// 讀取文件裏面的內容
$fileObj = $file->openFile('r');
while($fileObj->valid()){
echo $fileObj->fgets(); // 讀取文件裏的一行數據
}
// 關閉打開的文件
$fileObj = null;
$file = null;複製代碼
目錄相關函數:php.net/manual/zh/r…
文件系統函數:php.net/manual/zh/r….net
以上官方文檔都比較完善,而且翻譯完整使用自行學習。同時也有助於理解 SPL 的文件操做,由於 SPL 裏的方法與這裏的函數命名是一致的。