我需要在指定目录中获取JPG文件的总数,包括所有它的子目录。没有子目录。
结构如下:
dir1/ 2 files subdir 1/ 8 files
总 dir1 = 10个文件
dir2/ 5 files subdir 1/ 2 files subdir 2/ 8 files
总 dir2 = 15个文件
我有这个功能,它不能很好地工作,因为它只计算最后一个子目录中的文件,总数是实际文件数量的2倍。 (如果我在最后一个子目录中有40个文件,则输出80)
public function count_files($path) {
global $file_count;
$file_count = 0;
$dir = opendir($path);
if (!$dir) return -1;
while ($file = readdir($dir)) :
if ($file == '.' || $file == '..') continue;
if (is_dir($path . $file)) :
$file_count += $this->count_files($path . "/" . $file);
else :
$file_count++;
endif;
endwhile;
closedir($dir);
return $file_count;
}
答案 0 :(得分:6)
为了它的乐趣,我把它一起搅打:
class FileFinder
{
private $onFound;
private function __construct($path, $onFound, $maxDepth)
{
// onFound gets called at every file found
$this->onFound = $onFound;
// start iterating immediately
$this->iterate($path, $maxDepth);
}
private function iterate($path, $maxDepth)
{
$d = opendir($path);
while ($e = readdir($d)) {
// skip the special folders
if ($e == '.' || $e == '..') { continue; }
$absPath = "$path/$e";
if (is_dir($absPath)) {
// check $maxDepth first before entering next recursion
if ($maxDepth != 0) {
// reduce maximum depth for next iteration
$this->iterate($absPath, $maxDepth - 1);
}
} else {
// regular file found, call the found handler
call_user_func_array($this->onFound, array($absPath));
}
}
closedir($d);
}
// helper function to instantiate one finder object
// return value is not very important though, because all methods are private
public static function find($path, $onFound, $maxDepth = 0)
{
return new self($path, $onFound, $maxDepth);
}
}
// start finding files (maximum depth is one folder down)
$count = $bytes = 0;
FileFinder::find('.', function($file) use (&$count, &$bytes) {
// the closure updates count and bytes so far
++$count;
$bytes += filesize($file);
}, 1);
echo "Nr files: $count; bytes used: $bytes\n";
您传递基本路径,找到处理程序和最大目录深度(-1表示禁用)。找到的处理程序是您在外部定义的函数,它将从find()
函数中给出的路径相对传递路径名。
希望它有意义并帮助你:)
答案 1 :(得分:6)
你可以使用RecursiveDirectoryIterator
这样做<?php
function scan_dir($path){
$ite=new RecursiveDirectoryIterator($path);
$bytestotal=0;
$nbfiles=0;
foreach (new RecursiveIteratorIterator($ite) as $filename=>$cur) {
$filesize=$cur->getSize();
$bytestotal+=$filesize;
$nbfiles++;
$files[] = $filename;
}
$bytestotal=number_format($bytestotal);
return array('total_files'=>$nbfiles,'total_size'=>$bytestotal,'files'=>$files);
}
$files = scan_dir('./');
echo "Total: {$files['total_files']} files, {$files['total_size']} bytes\n";
//Total: 1195 files, 357,374,878 bytes
?>
答案 2 :(得分:1)
error_reporting(E_ALL);
function printTabs($level)
{
echo "<br/><br/>";
$l = 0;
for (; $l < $level; $l++)
echo ".";
}
function printFileCount($dirName, $init)
{
$fileCount = 0;
$st = strrpos($dirName, "/");
printTabs($init);
echo substr($dirName, $st);
$dHandle = opendir($dirName);
while (false !== ($subEntity = readdir($dHandle)))
{
if ($subEntity == "." || $subEntity == "..")
continue;
if (is_file($dirName . '/' . $subEntity))
{
$fileCount++;
}
else //if(is_dir($dirName.'/'.$subEntity))
{
printFileCount($dirName . '/' . $subEntity, $init + 1);
}
}
printTabs($init);
echo($fileCount . " files");
return;
}
printFileCount("/var/www", 0);
刚检查过,它正在运行。但是结果的排列很糟糕,逻辑起作用
答案 3 :(得分:1)
开发人员的答案实际上是非常出色的! 像这样使用它来使其工作:
System(“ find。-type f -print | wc -l”);
答案 4 :(得分:0)
如果有人想要计算文件和目录的总数。
显示/计算总目录和子目录数
find . -type d -print | wc -l
显示/计算主目录和子目录中的文件总数
find . -type f -print | wc -l
仅显示/计算当前目录中的文件(无子目录)
find . -maxdepth 1 -type f -print | wc -l
显示/计算当前目录中的总目录和文件(无子目录)
ls -1 | wc -l
答案 5 :(得分:-3)
每个循环的A可以更快地完成这个技巧; - )
我记得,opendir派生自SplFileObject类,它是一个RecursiveIterator,Traversable,Iterator,SeekableIterator类,因此,如果使用SPL标准PHP库来检索整个图像计数,则不需要while循环甚至在子目录中。
但是,有一段时间我没有使用PHP,所以我可能犯了一个错误。