文件查找(c語言 findfirst函數(shù),findnext函數(shù))
那么到底如何查找文件呢?我們需要一個(gè)結(jié)構(gòu)體和幾個(gè)大家可能不太熟悉的函數(shù)。這些函數(shù)和結(jié)構(gòu)體在的頭文件中,結(jié)構(gòu)體為struct _finddata_t ,函數(shù)為_findfirst、_findnext和_fineclose。具體如何使用,我會(huì)慢慢講來~ 首先講這個(gè)結(jié)構(gòu)體吧~ struct _finddata_t ,這個(gè)結(jié)構(gòu)體是用來存儲(chǔ)文件各種信息的。說實(shí)話,這個(gè)結(jié)構(gòu)體的具體定義代碼,我沒有找到,不過還好,文檔里面在_find里有比較詳細(xì)的成員變量介紹。我基本上就把文檔翻譯過來講吧:
unsigned atrrib:
文件屬性的存儲(chǔ)位置。它存儲(chǔ)一個(gè)unsigned單元,用于表示文件的屬性。
文件屬性是用位表示的,主要有以下一些:
_A_ARCH(存檔)
A_HIDDEN(隱藏)
_A_NORMAL(正常)
_A_RDONLY(只讀)
_A_SUBDIR(文件夾)
_A_SYSTEM(系統(tǒng))
這些都是在中定義的宏,可以直接使用,而本身的意義其實(shí)是一個(gè)無符號(hào)整型(只不過這個(gè)整型應(yīng)該是2的幾次冪,從而保證只有一位為1,而其他位為0)。既然是位表示,那么當(dāng)一個(gè)文件有多個(gè)屬性時(shí),它往往是通過位或的方式,來得到幾個(gè)屬性的綜合。例如只讀+隱藏+系統(tǒng)屬性,應(yīng)該為:_A_HIDDEN | _A_RDONLY | _A_SYSTEM 。
time_t time_create:
這里的time_t是一個(gè)變量類型(長(zhǎng)整型?相當(dāng)于long int?),用來存儲(chǔ)時(shí)間的,我們暫時(shí)不用理它,只要知道,這個(gè)time_create變量是用來存儲(chǔ)文件創(chuàng)建時(shí)間的就可以了。
time_t time_access:
文件最后一次被訪問的時(shí)間。
time_t time_write:
文件最后一次被修改的時(shí)間。
_fsize_t size:
文件的大小。這里的_fsize_t應(yīng)該可以相當(dāng)于unsigned整型,表示文件的字節(jié)數(shù)。
char name[_MAX_FNAME]:
文件的文件名。這里的_MAX_FNAME是一個(gè)常量宏,它在頭文件中被定義,表示的是文件名的最大長(zhǎng)度。
以此,我們可以推測(cè)出,struct _finddata_t ,大概的定義如下:
struct _finddata_t
{
unsigned attrib;
time_t time_create;
time_t time_access;
time_t time_write;
_fsize_t size;
char name[_MAX_FNAME];
};
前面也說了,這個(gè)結(jié)構(gòu)體是用來存儲(chǔ)文件信息的,那么如何把一個(gè)硬盤文件的文件信息“存到”這個(gè)結(jié)構(gòu)體所表示的內(nèi)存空間里去呢?這就要靠_findfirst、_findnext和_fineclose三個(gè)函數(shù)的搭配使用了。 首先還是對(duì)這三個(gè)函數(shù)一一介紹一番吧……
long _findfirst( char *filespec, struct _finddata_t *fileinfo );
返回值:
如果查找成功的話,將返回一個(gè)long型的唯一的查找用的句柄(就是一個(gè)唯一編號(hào))。這個(gè)句柄將在_findnext函數(shù)中被使用。若失敗,則返回-1。
參數(shù):
filespec:標(biāo)明文件的字符串,可支持通配符。比如:*.c,則表示當(dāng)前文件夾下的所有后綴為C的文件。
fileinfo :這里就是用來存放文件信息的結(jié)構(gòu)體的指針。這個(gè)結(jié)構(gòu)體必須在調(diào)用此函數(shù)前聲明,不過不用初始化,只要分配了內(nèi)存空間就可以了。
函數(shù)成功后,函數(shù)會(huì)把找到的文件的信息放入這個(gè)結(jié)構(gòu)體中。
int _findnext( long handle, struct _finddata_t *fileinfo );
返回值:
若成功返回0,否則返回-1。
參數(shù):
handle:即由_findfirst函數(shù)返回回來的句柄。
fileinfo:文件信息結(jié)構(gòu)體的指針。找到文件后,函數(shù)將該文件信息放入此結(jié)構(gòu)體中。
int _findclose( long handle );
返回值:成功返回0,失敗返回-1。
參數(shù): handle :_findfirst函數(shù)返回回來的句柄。
大家看到這里,估計(jì)都能猜到個(gè)大概了吧?先用_findfirst查找第一個(gè)文件,若成功則用返回的句柄調(diào)用_findnext函數(shù)查找其他的文件,當(dāng)查找完畢后用,用_findclose函數(shù)結(jié)束查找。恩,對(duì),這就是正確思路。下面我們就按照這樣的思路來編寫一個(gè)查找C:\WINDOWS文件夾下的所有exe可執(zhí)行文件的程序。
#include <stdio.h>
#include <direct.h>
#include <stdlib.h>
const char *to_search="C:\\WINDOWS\\*.exe"; //欲查找的文件,支持通配符
int main() {
long handle; //用于查找的句柄
struct _finddata_t fileinfo; //文件信息的結(jié)構(gòu)體
handle=_findfirst(to_search,&fileinfo); //第一次查找
if(-1==handle)return -1; printf("%s\n",fileinfo.name); //打印出找到的文件的文件名
while(!_findnext(handle,&fileinfo)) //循環(huán)查找其他符合的文件,知道找不到其他的為止
{
printf("%s\n",fileinfo.name);
}
findclose(handle); //別忘了關(guān)閉句柄
system("pause");
return 0;
}
*博客內(nèi)容為網(wǎng)友個(gè)人發(fā)布,僅代表博主個(gè)人觀點(diǎn),如有侵權(quán)請(qǐng)聯(lián)系工作人員刪除。