答案是使用PHP递归函数遍历目录中所有文件和子目录,累加文件大小以计算总大小。函数首先检查路径是否为有效目录,打开目录后逐个读取条目,跳过“.”和“..”,对文件直接获取大小,对子目录递归调用自身。最终返回总字节数,并可通过格式化函数转换为KB、MB或GB显示。示例代码包含错误处理与资源释放,适用于常规目录统计,但需注意权限、执行时间及符号链接可能导致的无限循环问题,也可用RecursiveIteratorIterator优化性能。

使用PHP递归函数计算目录大小 是一个常见的需求,特别是在开发文件管理系统或需要监控磁盘使用情况时。PHP本身不提供直接获取整个目录大小的函数,但可以通过递归遍历目录中的所有文件并累加其大小来实现。
基本思路说明
要统计一个目录的总大小,需要:- 遍历目录中的每一个条目(文件或子目录)
- 如果是文件,获取其大小并加入总和
- 如果是子目录,递归调用函数处理该子目录
- 将所有结果相加,返回总大小
递归函数实现示例
以下是一个完整的PHP函数,用于递归计算目录大小:
function getDirectorySize($path) {
$totalSize = 0;
// 检查路径是否存在且为目录
if (!is_dir($path)) {
return 0;
}
// 打开目录句柄
$dir = opendir($path);
if ($dir === false) {
return 0;
}
while (($file = readdir($dir)) !== false) {
// 跳过当前目录和上级目录符号
if ($file == '.' || $file == '..') {
continue;
}
$fullPath = $path . '/' . $file;
if (is_file($fullPath)) {
$totalSize += filesize($fullPath);
} elseif (is_dir($fullPath)) {
$totalSize += getDirectorySize($fullPath); // 递归调用
}
}
closedir($dir);
return $totalSize;
}
使用示例与格式化输出
调用上面的函数并以易读方式显示结果:
$directory = '/path/to/your/directory';
$sizeInBytes = getDirectorySize($directory);
// 将字节转换为 KB、MB 或 GB
function formatSize($bytes) {
if ($bytes < 1024) {
return $bytes . ' B';
} else if ($bytes < 1024 1024) {
return round($bytes / 1024, 2) . ' KB';
} else if ($bytes < 1024 1024 1024) {
return round($bytes / (1024 1024), 2) . ' MB';
} else {
return round($bytes / (1024 1024 1024), 2) . ' GB';
}
}
echo "目录大小:" . formatSize($sizeInBytes);
注意事项与优化建议
在实际使用中需要注意以下几点:- 确保PHP有权限读取目标目录及其中的所有文件
- 大目录可能导致执行时间较长,可适当提高脚本最大执行时间:
set_time_limit(300); - 避免符号链接造成的无限递归(可根据需要添加
is_link()判断) - 如需更高性能,可考虑使用
RecursiveIteratorIterator和RecursiveDirectoryIterator类代替手动递归
基本上就这些。这个递归方法简单有效,适合大多数场景下的目录大小统计需求。
立即学习“PHP免费学习笔记(深入)”;











