list_files

函数
list_files ( $folder = '', $levels = 100, $exclusions = array() )
参数
  • (string) $folder Optional. Full path to folder. Default empty.
    Required:
    Default: (empty)
  • (int) $levels Optional. Levels of folders to follow, Default 100 (PHP Loop limit).
    Required:
    Default: 100
  • (string[]) $exclusions Optional. List of folders and files to skip.
    Required:
    Default: array()
返回值
  • (string[]|false) Array of files on success, false on failure.
定义位置
相关方法
wp_list_filtervalidate_filewp_list_widgetslist_catsis_single
引入
2.6.0
弃用
-

list_files: 这是WordPress中的一个函数,显示一个目录中的文件列表。你可以在你的主题或插件中使用这个函数来显示一个指定目录中的文件列表,并可以选择按文件类型或其他标准进行过滤。

返回指定文件夹和所有子目录中的所有文件的列表,最深为100层。

递归的深度可以由 $levels 参数控制。

function list_files( $folder = '', $levels = 100, $exclusions = array() ) {
	if ( empty( $folder ) ) {
		return false;
	}

	$folder = trailingslashit( $folder );

	if ( ! $levels ) {
		return false;
	}

	$files = array();

	$dir = @opendir( $folder );

	if ( $dir ) {
		while ( ( $file = readdir( $dir ) ) !== false ) {
			// Skip current and parent folder links.
			if ( in_array( $file, array( '.', '..' ), true ) ) {
				continue;
			}

			// Skip hidden and excluded files.
			if ( '.' === $file[0] || in_array( $file, $exclusions, true ) ) {
				continue;
			}

			if ( is_dir( $folder . $file ) ) {
				$files2 = list_files( $folder . $file, $levels - 1 );
				if ( $files2 ) {
					$files = array_merge( $files, $files2 );
				} else {
					$files[] = $folder . $file . '/';
				}
			} else {
				$files[] = $folder . $file;
			}
		}

		closedir( $dir );
	}

	return $files;
}

常见问题

FAQs
查看更多 >