- <span style="font-size:18px;">function my_scandir($dir)
- {
- $files = array();
- if ( $handle = opendir($dir) ) {
- while ( ($file = readdir($handle)) !== false ) {
- if ( $file != ".." && $file != "." ) {
- if ( is_dir($dir . "/" . $file) ) {
- $files[$file] = scandir($dir . "/" . $file);
- }else {
- $files[] = $file;
- }
- }
- }
- closedir($handle);
- return $files;
- }
- }</span>
opendir -- 打开目录句柄
说明 resource opendir ( string path)
返回一个目录句柄,可以在之后用在 closedir(),readdir() 和 rewinddir() 调用中。
如果 path 不是一个合法的目录或者因为权限限制或文件系统错误而不能打开目录,opendir() 返回 FALSE 并产生一个 E_WARNING 级别的 PHP 错误信息。可以在 opendir() 前面加上“@”符号来抑制错误信息的输出。
readdir -- 从目录句柄中读取条目
说明 string readdir ( resource dir_handle)
返回目录中下一个文件的文件名。文件名以在文件系统中的排序返回。
请留意下面例子中检查 readdir() 返回值的风格。我们明确地测试返回值是否全等于(值和类型都相同 - 更多信息参见比较运算符)FALSE,否则任何目录项的名称求值为 FALSE 的都会导致循环停止(例如一个目录名为“0”)。
is_dir -- 判断给定文件名是否是一个目录
说明bool is_dir ( string filename)
如果文件名存在并且为目录则返回 TRUE。如果 filename 是一个相对路径,则按照当前工作目录检查其相对路径。
scandir -- 列出指定路径中的文件和目录
说明array scandir ( string directory [, int sorting_order])
返回一个 array,包含有 directory 中的文件和目录。如果 directory 不是一个目录,则返回布尔值 FALSE,并产生一条 E_WARNING 级别的错误。
默认情况下,返回值是按照字母顺序升序排列的。如果使用了可选参数 sorting_order(设为 1),则按照字母顺序降序排列。