登录 | 注册

首页 | 学习中心 | 下载中心 | 知识大全 | 作文 | 常识 | 加入收藏 | 网站地图

您当前位置:多思学习网知识频道电脑学习软件技巧通过递归调用来搜索文件

通过递归调用来搜索文件

11-08 12:39:07软件技巧
浏览次数:444次 
标签:软件技巧大全,http://www.duosi8.com 通过递归调用来搜索文件,

  在我们编写程序的时候,经常会在目录和子目录中搜索文件,但Delphi并没有为我们提供这一功能函数,它为我们提供了一些只能在当前目录查找文件的函数,不过现在在网上也能找到一些可以实现此功能的控件,例如FileSearch等等。那么我们要自己编写这个功能,又应该怎样做呢?其实本功能最难实现的部分就是要编写能逐层访问目录的算法。经本人研究,终于得出一个实现它的方法,那就是利用递归调用算法来实现,现将实现过程介绍如下:
1. 窗体设计
新建一个工程,在Form1中添加DriveComboBox1、Edit1、Listbox1、Button1、DirectoryOutline1、Label1,把Edit1的Text属性改为*.*,Button1的Caption属性改为“查找”。
2.程序清单
unit main;
interface
uses
  Windows, Messages, SysUtils, Classes, Graphics,
  Controls, Forms, Dialogs,stdctrls,filectrl,grids,outline,diroutln;
type
  TForm1 = class(TForm)
    DriveComboBox1: TDriveComboBox;
    Edit1: TEdit;
    Listbox1: TListBox;
    Button1: TButton;
    Label1: TLabel;
    DirectoryOutline1: TDirectoryOutline;
    procedure Button1Click(Sender: TObject);
    procedure DriveComboBox1Change(Sender: TObject);
  private
    { Private declarations }
  ffilename:string;
  function getdirectoryname(dir:string):string;
  procedure findfiles(apath:string);
  public
    { Public declarations }
  end;

var
  Form1: TForm1;
  t:integer;
implementation

{$R *.DFM}
function tForm1.getdirectoryname(dir:string):string;
{对文件名进行转换,使之以反斜杠结尾}
  begin
    if dir[length(dir)]<>'\' then
      result:=dir+'\'
    else
      result:=dir;
  end;
procedure TForm1.findfiles(apath: string);
{通过递归调用,可以在当前目录和子目录下查找指定格式的文件}
var
  fsearchrec,dsearchrec:tsearchrec;
  findresult:integer;
function isdirnotation(adirname:string):boolean;
   begin
    result:=(adirname='.') or (adirname='..');
   end;
begin
apath:=getdirectoryname(apath); //获取一个有效的目录名称
{查找一个匹配的文件}
findresult:=findfirst(apath+ffilename,faanyfile+fahidden+fasysfile+fareadonly,fsearchrec);
try
{继续查找匹配的文件}
 while findresult=0 do
  begin
   Listbox1.Items.Add(lowercase(apath+fsearchrec.Name));
   t:=t+1;
   label1.Caption:=inttostr(t);
   findresult:=findnext(fsearchrec);
  end;
{在当前目录的子目录中进行查找}
findresult:=findfirst(apath+'*.*',fadirectory,dsearchrec);
while findresult=0 do
  begin
    if ((dsearchrec.Attr and fadirectory)=fadirectory) and not
      isdirnotation(dsearchrec.Name) then
      findfiles(apath+dsearchrec.Name);//在此处是递归调用
    findresult:=findnext(dsearchrec);
  end;
finally
 findclose(fsearchrec);
end;
end;
procedure TForm1.Button1Click(Sender: TObject);
{调用FindFiles()函数,用来搜索子目录}
begin
t:=0;
screen.Cursor:=crhourglass;
 try
  Listbox1.Items.Clear;
  ffilename:=Edit1.Text;
  findfiles(DirectoryOutline1.Directory);
 finally
screen.Cursor:=crdefault;
end;
end;
procedure TForm1.DriveComboBox1Change(Sender: TObject);
begin
DirectoryOutline1.Drive:=DriveComboBox1.Drive;
end;
end.

怎么样,完成了吗?把它再完善一下就可以成为一个可以在所有驱动器中查找文件的程序了。本程序在WinME/Delphi5中运行通过。
(本文代码已经收入本期光盘)

,通过递归调用来搜索文件
《通过递归调用来搜索文件》相关文章

tag: 软件技巧,软件技巧大全,电脑学习 - 软件技巧

联系我们 | 网站地图 | 幼教大全 | 试题下载 | 电脑学习 | 加入收藏


幼儿园教案_ 教案模板_ 课件模板_ 教学反思_ 教学计划


多思学习网 1 2 3 4 5 6