函数FindFirstFile
文件查找
Struct Lnode{
Char table[256]; //保存文件夹名
Struct Lnode*next;
}
加文件夹入链表
Lnode *newList;
Void AddList(char *list) //list为文件夹名
{
NewList=new Lnode;
Strcpy(NewList->table,list);
newList->next=NULL;
if(h->next==NULL)
h->next=newList; //h为头结点
else
{
r->next=newList; //r始终指向尾节点
r=newList;
}
}
FindFirstFile和FindNextFile
HANDLE FindFirstFile{
LPCTSTR IpFileName; //指向要查找的文件名(包含路径)
LPWIN32_FIND_DATA IpFindFileData; //输出参数,指向一个结构。此结构可以描述找到的文件或文件夹的属性。
}
函数调用成功则返回可供函数FindNextFile和函数FindClose使用的查找句柄,否则返回INVALID_HANDLE_VALUE;
Typedef struct _WIN32_FIND_DATA{
DWORD dwFileAttributes; //文件属性
FILETIME ftCreationTime; //创建文件的时间
FILETIME ftLastAccessTime; //最近一次访问文件的时间
FILETIME ftLastWriteTime; //最近一次修改文件的时间
DWORD nFileSizeHigh //文件大小的高位字
DWORD nFileSizeLow; //文件大小的地位字
DWORD dwReserved0; //保留,未使用
DWORD dwReserved1; //保留,未使用
TCHAR cFileName[MAX_PATH]; //文件的名称
TCHAR cAlternateFileName[14]; //文件的替换名称,用文件名.后缀名表示
} WIN32_FIND_DATA,*p WIN32_FIND_DATA;
BOOL FindNextFile {
HANDLE hFindFile; //此参数指向了函数FindFirstFile返回的查找句柄
LPWIN32_FIND_DATA IpFindFileData;
}
函数调用成功则返回可供函数FindNextFile和函数FindClose使用的查找句柄,否则返回INVALID_HANDLE_VALUE;
查找文件一般使用的结构
hFindFile=FindFirstFile(IpFileName,&IpFindData);
if(hFindFile!=INVALID_HANDLE_VALUE)
{
Do
{
}while(FindNextFile(hFindFile,&findData))
}
遍历目录
Void FindFile(char *pRoad,char *pFile)
//pRoad为要查找的路径,pFile为要查找的文件
{
Char FileRoad[256]={0};//要查找文件的路径
Char DirRoad[256]={0};//存放要查找的路径
Char FindedFile[256]={0};
Char FindedDir[256]={0};//存放找到的是文件夹的路径
Strcpy(FileRoad,pRoad);
Strcpy(DirRoad,pRoad);
Strcat(DirRoad,”\\*.*”);
//查找文件,把找到的放入文件夹链表
WIN32_FIND_DATA findData;
HANDLE hFindFile;
hFindFile=FindFirstFile(DirRoad,&findData);
if(hFindFile!=INVALID_HANDLE_VALUE)
{
Do
{
If(findData.cFileName[0]==’.’)
Continue;
If(findData.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)
{
Strcpy(FindedDir,pRoad);
Strcat(FindedDir,”\\”);
Strcat(FindDir,findData.cFileName);
AddList(FindDir);
Memset(FindDir,0x00,256);
}
}while(FindNextFile(hFindFile,&findData));
}
Strcat(FileRoad,”\\”);
Strcat(FileRoad,pFile);
//查找要查找的文件
hFindFile=FindFirstFile(FileRoad,&findData);
if(hFindFile!=INVALID_HANDLE_VALUE)
{
Do{
Strcpy(FindedFile,pRoad);
Strcat(FindedFile,”\\”);
Strcat(FindedFile,findData.cFileName);
Printf(“%s\n”,FindedFile);
Memset(FindedFile,0x00,256);
}while(FindNextFile(hFindFile,&findData));
}
}
Int searchFile(char * Directory,char *SeachFile)
{
Lnode newList;
Strcpy(newList->table,Directory);
newList->next=NULL;
while(true)
{
Lnode *Find;
If(r->next!=NULL)
{
Find=r->next;
r->next=r->next->next;
FindFile(Find->table,searchFile);
}
Else
{
Printf(“文件搜索完毕\n”);
Return 0;
}
}
Return 0;
}
函数FindFirstFile的更多相关文章
- [php代码审计] Window api函数 FindFirstFile 在php中的问题
include文件夹中文件: 内容: <?php echo __FILE__; ?> index.php: 演示如下: “<<”替换多个任意字符: “>”替换单个字符:
- c#调用api(FindFirstFile,FindNextFile)高效遍历目录文件【转载】
在c#下遍历目录,应用最多的应该就是 System.IO.DirectoryInfo.GetDirectories或GetFiles了,但是当目录特别大,文件特别多时,效率不尽人意,此时我们很容易想到 ...
- windows中操作文件和目录的函数
1.文件操作函数 CreateFile();//创建或打开文件 ReadFile();//从文件读 WriteFile();//向文件写 SetFilePoi ...
- Windows FindFirstFile利用
目前大多数程序都会对上传的文件名加入时间戳等字符再进行MD5,然后下载文件的时候通过保存在数据库里的文件ID读取文件路径,一样也实现了文件下载,这样我们就无法直接得到我们上传的webshell文件路径 ...
- C/C++ 中判断某一文件或目录是否存在
方法一:C++中比较简单的一种办法(使用文件流打开文件) #include <iostream> #include <fstream> using namespace std; ...
- php黑魔法之解析问题
code如下: <?php $a=$_GET[a]; $b=is_file($a); var_dump($b); ?> 可以看到1.ph< 返回了true 这样不就可以绕过这个的过滤 ...
- Deformity PHP Webshell、Webshell Hidden Learning
目录 . 引言 . webshell原理介绍 . webshell的常见类型以及变种方法 . webshell的检测原理以及检测工具 . webshell隐藏反检测对抗手段 0. 引言 本文旨在研究W ...
- 在windows 、linux下读取目录下所有文件名
Windows要引入的头文件是<Windows.h> 主要是两个函数FindFirstFile.FindNextFile MSDN里是这么说的: FindFirstFile functio ...
- SIFT算法的应用--目标识别之Bag-of-words模型
原文:http://blog.csdn.net/v_JULY_v/article/details/6555899 SIFT算法的应用 -目标识别之用Bag-of-words模型表示一幅图像 作者:wa ...
随机推荐
- digitalocean开通德国法兰克福机房,40Gb带宽,支持IPv6
2015年4月15日,vps服务商digitalocean宣布正式开通德国法兰克福机房.5个月前digitalocean宣布筹备Germany机房中心,经过近1个月部署,总算与用户见面了.Frankf ...
- vc中主线程等待子线程退出的方法
VC线程同步,在子线程中等待另一子线程结束,通过WaitForSingleObject可以实现,但是如果在主线程中等待子线程结束,这个函数是无法完成要求的,因为它会造成主线程挂起,导致程序死掉.我们可 ...
- SharePoint 2013 InfoPath 无法保存下列表单
转载自:http://www.cnblogs.com/jianyus/p/3470121.html 在使用InfoPath发布表单,发布到SharePoint服务器报错,如下介绍: 环境:Window ...
- mysql高级查询
高级查询: 1.连接查询 select * from Info,Nation #得出的结果称为笛卡尔积select * from Info,Nation where Info.Nation = Nat ...
- 设正整数n的十进制表示为n=ak……a1a0(0<=ai<=9,0<=i<=k,ak!=0),n的个位为起始数字的数字的正负交错之和T(n)=a0+a1+……+(-1)kak,证明:11|n的充分必要条件是11|T(n);(整除理论1.1.2))
设正整数n的十进制表示为n=ak……a1a0(0<=ai<=9,0<=i<=k,ak!=0),n的个位为起始数字的数字的正负交错之和T(n)=a0+a1+……+(-1)kak, ...
- 一些常见warning的原因和解决方法
在入职三周后,终于赶齐了接手项目落下两个月的项目,有了一些自己的空闲时间对项目进行整理.主要整理包括类目的整合,从原来一个系统文件夹下几百个文件整改为以MVC设计思想为原则的分文件夹整理类目,井然有序 ...
- CF/div2c/贪心
题目链接[http://codeforces.com/contest/749/problem/C] 题意:给出一个长度为n序列包含D和R,每一轮操作的先后顺序是1-n,规则是每一轮每个人有一次机会杀掉 ...
- javascript中函数的call,apply及bind方法
call 方法调用一个对象的一个方法,以另一个对象替换当前对象.call([thisObj[,arg1[, arg2[, [,.argN]]]]])参数thisObj可选项.将被用作当前对象的对象. ...
- PHPExcel解决内存占用过大问题-dw 查找memoryCacheSize把1M改为2048M
http://blog.sina.com.cn/s/blog_4ec7952d0101fcrd.html PHPExcel解决内存占用过大问题-设置单元格对象缓存 PHPExcel是一个很强大的处理E ...
- 嵌套表SHAPE
SQL语法 SHAPE {<master query>} APPEND ({ <child table query> } RELATE <master column> ...