文件历遍搜索详解

文件历遍看搜索主要用二个Windows API,分别是 FindFirst 和FindNext.他们的返回类

型为TSearchRec

TSearchRec结构:

TSearchRec = record
   Time: Integer;
   Size: Integer;
   Attr: Integer;
   Name: TFileName;
   ExcludeAttr: Integer;
   FindHandle: THandle;
   FindData: TWin32FindData;
end;

其中Size表示文件的大小,Name是文件的名称;Attr是文件的属性,Time包括创建和修改文件的时间;

Attr 属性有 faReadOnly(只读文件),faHidden(隐藏),faSysFile(系统),aVolumeID(卷标),faDirectory(文件夹),faArchive(存档),faAnyFile(任何).

下面是详细代码:

unit SearchFUnit;

interface

uses
  SysUtils, Classes;

  procedure FindFile(APath, FName: String;FList: TStrings);
  procedure GetDirectoryName(Dir: String): String;
  function IsDirNotation(ADirName: String): Boolean;

implementation

procedure FindFile(APath, FName: String;FList: TStrings);
var
  FSearchRec,
  DSearchRec: TSearchRec;
  FindResult: integer;
begin
    APath := GetDirectoryName(APath);
    FindResult := FindFirst(APath + AName,faAnyFile + faHidden +
                  faSysFile + faReadOnly,FSearchRec);
    try
      while FindResult = 0 do
      begin
          FList.Add(APath + FSearchRec.Name);
        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
          FindFile(APath + DSearchRec.Name,FName, FList);
        FindResult := FindNext(DSearchRec);
      end;
    finally
      FindClose(FSearchRec);
    end;
end;

function GetDirectoryName(Dir: String): String;
begin
  if Dir[Length(Dir)] <> '/' then
    Result := Dir + '/'
  else
    Result := Dir;
end;

function IsDirNotation(ADirName: String): Boolean;
begin
  Result := (ADirName = '.') or (ADirName = '..');
end;

end.

 在这个方法中,通过第一个while..do循环在参数Apath指定的目录下进行查找,找到并添加到FList中,在第二个while..do循环是对指定目录的字目录进行查找,利用得到的子目录依次作为APath参数,递归调用FindFile,地到所有目录都被查到为止.

 在这个方法中,通过第一个while..do循环在参数Apath指定的目录下进行查找,找到并添加到FList中,在第二个while..do循环是对指定目录的字目录进行查找,利用得到的子目录依次作为APath参数,递归调用FindFile,地到所有目录都被查到为止.

我们单步执行调试,可以完整的看到整个过程!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
wav文件是一种常见的音频文件格式,它是由Microsoft和IBM共同定义的。下面是对wav文件格式的详解: 1. 文件头(Header):wav文件的前44个字节是文件头,包含了文件的基本信息。文件头的结构如下: - ChunkID(4字节):文件标识,通常为"RIFF"。 - ChunkSize(4字节):文件大小,即整个文件的大小减去8个字节(ChunkID和ChunkSize本身的大小)。 - Format(4字节):文件格式,通常为"WAVE"。 - Subchunk1ID(4字节):子块标识,通常为"fmt "。 - Subchunk1Size(4字节):子块大小,即除去Subchunk1ID和Subchunk1Size本身的大小。 - AudioFormat(2字节):音频格式,常见值为1表示PCM(脉冲编码调制)。 - NumChannels(2字节):声道数,常见值为1表示单声道,2表示立体声。 - SampleRate(4字节):采样率,即每秒采样的样本数。 - ByteRate(4字节):数据传输速率,即每秒传输的字节数。 - BlockAlign(2字节):数据块对齐,即每个采样的字节数。 - BitsPerSample(2字节):样本位数,即每个采样的位数。 2. 数据块(Data Chunk):文件头之后的部分是音频数据块,包含了实际的音频采样数据。数据块的结构如下: - Subchunk2ID(4字节):子块标识,通常为"data"。 - Subchunk2Size(4字节):子块大小,即音频数据的大小。 - Data(变长):音频数据,以二进制形式存储。 在wav文件中,音频数据以采样点的形式存储,每个采样点的值表示音频信号在该时间点上的幅度。采样点的位数(BitsPerSample)决定了每个采样点的精度,位数越高,精度越高,音频质量也越好。 总结起来,wav文件格式通过文件头和数据块来存储音频数据,其中文件头包含了文件的基本信息,数据块存储了实际的音频采样数据。通过解析文件头和读取数据块中的采样数据,可以对wav文件进行分析和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值