_finddata_t和 _findfirst 和 _findnext 查找文件

一、这两个函数均在io.h里面。

二、首先了解一下一个文件结构体:
struct _finddata_t {
unsigned attrib;
time_t time_create;
time_t time_access;
time_t time_write;
_fsize_t size;
char name[260];
};

time_t,其实就是long
而_fsize_t,就是unsigned long

现在来解释一下结构体的数据成员吧。

attrib,就是所查找文件的属性:_A_ARCH(存档)、_A_HIDDEN(隐藏)、_A_NORMAL(正常)、_A_RDONLY(只读)、 _A_SUBDIR(文件夹)、_A_SYSTEM(系统)当一个文件有多个属性时,它往往是通过位或的方式,来得到几个属性的综合。例如只读+隐藏+系统属性,应该为:_A_HIDDEN | _A_RDONLY | _A_SYSTEM 。

time_create、time_access和time_write分别是创建文件的时间、最后一次访问文件的时间和文件最后被修改的时间。

size:文件大小

name:文件名。


三、用 _findfirst 和 _findnext 查找文件

1、_findfirst函数:long _findfirst(const char *, struct _finddata_t *);

第一个参数为文件名,可以用"*.*"来查找所有文件,也可以用"*.cpp"来查找.cpp文件。第二个参数是_finddata_t结构体指针。若查找成功,返回文件句柄,若失败,返回-1。


2、_findnext函数:int _findnext(long, struct _finddata_t *);

第一个参数为文件句柄,第二个参数同样为_finddata_t结构体指针。若查找成功,返回0,失败返回-1。

3、_findclose()函数:int _findclose(long);

只有一个参数,文件句柄。若关闭成功返回0,失败返回-1。


四、查找文件例子

#include <io.h>
#include <iostream>
using namespace std;

int main()
{
_finddata_t file;
int k;
long HANDLE;
k = HANDLE = _findfirst( "*.*", &file );
while( k != -1 )
{
cout << file.name << endl;
k = _findnext( HANDLE, &file );
}
_findclose( HANDLE );

return 0;
}

以上转自:http://blog.sina.com.cn/s/blog_67e046d10100jwdo.html

void getFilesall(string path, vector<string>& files, vector<string>& filesname, string format) //获取指定路径下的
指定格式文件,存成列表
{
	//文件句柄  
	long   hFile = 0;
	//文件信息  
	struct _finddata_t fileinfo;  //很少用的文件信息读取结构,包含文件名称,时间,文件大小等
	string p;
	string name;
	if ((hFile = _findfirst(p.assign(path).append("\\*").c_str(), &fileinfo)) != -1) 
	{
		do
		{
			if ((fileinfo.attrib &  _A_SUBDIR))  //比较文件类型是否是文件夹
			{
				if (strcmp(fileinfo.name, ".") != 0 && strcmp(fileinfo.name, "..") != 0) 
				{
					//files.push_back(p.assign(path).append("\\").append(fileinfo.name));
					getFilesall(p.assign(path).append("\\").append(fileinfo.name), files, filesname, format);
				}
			}
			else
			{
				string filename = fileinfo.name;
				size_t filename_size = filename.length();
				string filetype = format; //文件后缀名
				string delpath; //大小为零的文件地址
				//wstring wdelpath;
				if (filename.compare((filename_size - 4), 4, filetype) == 0) //比较文件类型
				{
					if(fileinfo.size>0) //判断文件大小,保存文件
					{
						files.push_back(p.assign(path).append("\\").append(fileinfo.name));
						filesname.push_back(name.assign(fileinfo.name));
					}
					else  //删除文件
					{
						delpath = p.assign(path).append("\\").append(fileinfo.name);
						//wdelpath = AnsiToUnicode(delpath);
						DeleteFile(delpath.c_str()); 
						cout << fileinfo.name << "为空文件,删除成功" << endl;
					}

				}
			}
		} while (_findnext(hFile, &fileinfo) == 0);  //寻找下一个,成功返回0,否则-1 循环读取路径下的文件

		_findclose(hFile);
	}
}


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值