您的位置:首页 > 编程语言 > Delphi

理解 Delphi 的类(十) - 深入方法[28] - 递归函数实例: 搜索当前目录下的所有嵌套目录

2008-01-15 15:45 549 查看
//上面一个例子不能说明递归函数的本质, 直接来个实用的函数吧, 刚好要用.

unit Unit1;

interface

uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, StdCtrls;

type
TForm1 = class(TForm)
Button1: TButton;
Memo1: TMemo;
procedure Button1Click(Sender: TObject);
end;

var
Form1: TForm1;

implementation

{$R *.dfm}

//列出一个目录下所有目录(包括嵌套)的函数
procedure GetDirs(dirName: string; List: TStrings);
var
SRec: TSearchRec;            {定义 TSearchRec 结构变量}
dir: string;
const
attr: Integer = faDirectory; {文件属性常量, 表示这是文件夹}
begin
dirName := ExcludeTrailingBackslash(dirName) + '\'; {不知道最后是不是 \; 先去掉, 再加上}
dir := dirName + '*.*'; {加上 \; *.* 或 * 表示所有文件, 系统会把目录也当作一个文件}

if FindFirst(dir, attr, SRec) = 0 then {开始搜索,并给 SRec 赋予信息, 返回0表示找到第一个}
begin
repeat
if (SRec.Attr = attr) and              {如果是文件夹}
(SRec.Name <> '.') and              {排除上层目录}
(SRec.Name <> '..') then            {排除根目录}
begin
List.Add(dirName + SRec.Name);      {用List记下结果}
GetDirs(dirName + SRec.Name, List); {这句就是递归调用, 如果没有这句, 只能搜索当前目录}
end;
until(FindNext(SRec)<>0);                {找下一个, 返回0表示找到}
end;

FindClose(SRec);                           {结束搜索}
end;

{测试}
procedure TForm1.Button1Click(Sender: TObject);
var
list: TStrings;
begin
list := TStringList.Create;

GetDirs('C:\Downloads', list);
Memo1.Lines := list;

list.Free;
end;

end.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: