PHP Delphi CSS HTML JavaScript Perl API ASP MySQL XML С++ VBasic WEB разработка *NIX CouchDB Hack Python
Главная Статьи PHP Цикл от человека - Рекурсия от Бога
Главная
 Главная  Контакты
 
Программинг
Статьи Книги ЧаВО
 
xBOOKi
Fresh Books Операционки Сети
 
Поиск
-------
 
Counters
Яндекс цитирования
Rambler's Top100
-------
 
CryptDisk.4h
Программа которая позволяет создать виртуальный шифрованный логический диск.

cryptdisk.4hack.com

-------
 
 

Цикл от человека - Рекурсия от Бога .
(подсчет размера файлов в директории и в поддиректориях)

Введение
Предположим что вам нужно подсчитать размер всех файлов начиная с текущей директории , получить их число и количество вложенный поддиректорий. Подобные задачи решаться применением рекурсии - то есть обращения из функции к самой себе.

Решение задачи
Благодаря способности PHP выполнять рекурсивные запросы к функциям (а также к методам классов) стало возможным решить платформо - независимую задачу подсчета размера файлов в директориях.

Приведем пример класса на php решающего задачу подсчета размера всех файлов вложенный в директорию и в поддиректории:

Текст программы
class calc_dir{

var $a_fname=array();
var $a_fsize=array();
var $a_fdir =array();
var $cofiles;

function init()
{
$this->cofiles=0;
}

function calc_files($in_dir)
{
#Так можно отсечь нежелательные имена файлов
#if (preg_match("/_vti[.]*/i",$in_dir)){return;}

if ($dir_handle = @opendir($in_dir))
{
while($file = readdir($dir_handle))
{
//Рекурсивный проход по директориям
if ($file!=".." && $file!="." && is_dir($file))
{
$this->calc_files($in_dir."/".$file);
}

//Проход по файлам
if (is_file($in_dir."/".$file) && $file!=".." && $file!=".")
{
$this->a_fname[$this->cofiles]=$file;
$this->a_fsize[$this->cofiles]=filesize ($in_dir."/".$file);
$this->a_fdir [$this->cofiles]=$in_dir;
$this->cofiles++;

}
}
}
}

function show()
{
echo "

";
$a_size=0;
for ($i=0;$ia_fname);$i++)

echo " ";
$a_size+=$this->a_fsize[$i];
}
echo " ";
echo "
i name size dir
".($i+1)." ".$this-> a_fname[$i]." ".$this->a_fsize[$i]." ".$this->a_fdir[$i]."
Total: $a_size

";
}

}//end class

$d=new calc_dir;
$d->init();
$d->calc_files("C:/windows/command/");
$d->show();
?>


Комментарии

Класс calc_dir имеет 3-ри метода (иначе говоря наша программа имеет три функции). Это :

$d->init();
- Метод исполняющий инициализацию класса (присваивает 0 счетчику найденых файлов) 
$d->calc_files();
- Метод (который вызывается рекурсивно) для перебора файлов и директорий в текущей директории 
$d->show();
Метод выводящий собранные данные в виде таблицы

Вызов класса начинается с его создания : $d=new calc_dir;
Поиск файлов начинается с какой-либо директории - для примера я взял директорию C:\windows\command - Если у вас ее нет возьмите какую либо другую , например текущую : $d->calc_files(".");
После выполнения поиска результаты выводятся с помощью метода класса $d->show().

 

Вариации на тему 
Если вы вдруг захотите отсортировать выводимые файлы по имени вам достаточно добавить в класс метод который может выглядеть вот так :

function sort ()
{
array_multisort (
$this->a_fname,
$this->a_fsize,
$this->a_fdir );
}

А в текст программы нужно добавить его вызов , вот так например :
$d=new calc_dir;
$d->init();
$d->calc_files("C:/windows/command/");
$d->sort();
$d->show();


Ccылки по теме
:
1. Скачать исходные тексты программы можно тут >>>
2. Статья "Поисковый механизм для вашего сайта , на PHP" по php на нашем сайте Перейти >>>
3. FAQ по PHP . Перейти>>>

24.06.2001 г.Львов Кириллов А.В.

 



Свежее
Резервное копирование rsync-ом
DNS Amplification (DNS усиление)
Алгоритм Шинглов — поиск нечетких дубликатов текста
Metasploit Framework. Обзор
Использование CouchDB
-------



 
Copyright © 2003-2009   Frikazoid.
Rambler's Top100