最近学到操作系统的文件管理,研究了一下文件查询,代码如下

1.完整版(老师给出的示例代码)

#include "windows.h"

#include "stdio.h"

int num=0;

void find(char *path,char *name)

{

char szFind[MAX_PATH],szFile[MAX_PATH];

WIN32_FIND_DATA fd;

sprintf(szFind,"%s\\%s",path,name);

HANDLE hFind=FindFirstFile(szFind,&fd);

if(INVALID_HANDLE_VALUE!=hFind)

{

while(1)

{

printf("\n%s\\%s\n",path,fd.cFileName);

num++;

if(!FindNextFile(hFind,&fd))break;

}

FindClose(hFind);

}

sprintf(szFind,"%s\\*.*",path);

hFind=FindFirstFile(szFind,&fd);

if(INVALID_HANDLE_VALUE==hFind)return;

while(TRUE)

{

if(fd.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)

{

if(fd.cFileName[0]!='.')

{

sprintf(szFile,"%s\\%s",path,fd.cFileName);

find(szFile,name);

}

}

if(!FindNextFile(hFind,&fd))break;

}

FindClose(hFind);

}

int main()

{

DWORD dwSize = MAX_PATH;

char szLogicalDrives[MAX_PATH] = {0};

char name[]="pra*.*";

//获取逻辑驱动器号字符串

DWORD dwResult = GetLogicalDriveStrings(dwSize,szLogicalDrives);

//处理获取到的结果

if (dwResult > 0 && dwResult <= MAX_PATH) {

char* szSingleDrive = szLogicalDrives;  //从缓冲区起始地址开始

while(*szSingleDrive)

{

printf("Drive: %s     ", szSingleDrive);   //输出单个驱动器的驱动器号

switch(GetDriveType(szSingleDrive))

{

case DRIVE_UNKNOWN    : puts("未知的磁盘类型"); break;

case DRIVE_NO_ROOT_DIR: puts("路径无效"); break;

case DRIVE_REMOVABLE  : puts("可移动磁盘"); break;

case DRIVE_FIXED      : puts("固定磁盘");

find(szSingleDrive,name);

break;

case DRIVE_REMOTE     : puts("网络磁盘"); break;

case DRIVE_CDROM      : puts("光驱"); break;

case DRIVE_RAMDISK    : puts("内存映射盘"); break;

default:break;

}

// 获取下一个驱动器号起始地址

szSingleDrive += strlen(szSingleDrive) + 1;

}

}

return 0;

}

2.分析

///获取盘符DWORD dwSize = MAX_PATH;    char szLogicalDrives[MAX_PATH] = {0};//获取逻辑驱动器号字符串    DWORD dwResult =GetLogicalDriveStrings(dwSize,szLogicalDrives);char* szSingleDrive =szLogicalDrives;  //从缓冲区起始地址开始while(* szSingleDrive){printf("Drive: %s     ", szSingleDrive);   szSingleDrive += strlen(szSingleDrive)+ 1;}///获取当前目录下目标文件char szFind[MAX_PATH];    WIN32_FIND_DATA fd;sprintf(szFind,"%s\\%s",path,name);HANDLEhFind=FindFirstFile(szFind,&fd);    if(INVALID_HANDLE_VALUE!=hFind)    {         while(1)         {            printf("\n%s\\%s\n",path,fd.cFileName);             num++;            if(!FindNextFile(hFind,&fd))break;         }         FindClose(hFind);     }///获取目录sprintf(szFind,"%s\\*.*",path);hFind=FindFirstFile(szFind,&fd);if(INVALID_HANDLE_VALUE==hFind)return0;while(TRUE) {     if(fd.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)       {          if(fd.cFileName[0]!='.')          {            sprintf(szFile,"%s\\%s",path,fd.cFileName);             find(szFile,name);//递归调用           }      }      if(!FindNextFile(hFind,&fd))break;    }FindClose(hFind);

3.知识点:

盘符的类型很多,可以用GetDriveType(当前盘符)【GetDriveType(szSingleDrive)】获取获取下一个盘符:szSingleDrive += strlen(szSingleDrive) + 1;文件: FindFirstFile(szFind,&fd)与FindNextFile(hFind,&fd),可以用或者判定前者是否结束 WIN32_FIND_DATA,该结构的内容如下:typedef struct _WIN32_FIND_DATA {                         DWORD dwFileAttributes; //文件属性

FILETIME ftCreationTime; // 文件创建时间

FILETIME ftLastAccessTime; // 文件最后一次访问时间

FILETIME ftLastWriteTime; // 文件最后一次修改时间

DWORD nFileSizeHigh; // 文件长度高32位

DWORD nFileSizeLow; // 文件长度低32位

DWORD dwReserved0; //统保留

DWORD dwReserved1; // 系系统保留

TCHAR cFileName[ MAX_PATH ]; // 长文件名

TCHAR cAlternateFileName[ 14 ]; // 8.3格式文件名

} WIN32_FIND_DATA, *PWIN32_FIND_DATA;

#define FILE_ATTRIBUTE_DIRECTORY  0x00000010  文件夹 第5位                        判断是文件还是目录

fd.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY   &:相同为1,不同为0

if(fd.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)运算为1就是文件夹,0为文件

if(fd.cFileName[0]!='.')  .表示当前路径,..表示后退一布路径

4.简单文件查询(根据windows自带的文件查询命令简化)

#include

#include

#include

int main()

{

DWORD dwDriveStrLen;

char wDrivesName[ 0x100 ];

dwDriveStrLen = sizeof( wDrivesName );

GetLogicalDriveStrings(dwDriveStrLen, wDrivesName);

char *p = ( char * )wDrivesName;//得到所有盘符

char str[1000],name[100];

scanf("%s",name);

while( *p )

{

sprintf(str,"for /r %s %%i in (%s) do @echo %%i",p,name);

p += ( strlen( p ) + 1 );

system(str);//执行查询命令

}

return 0;

}

c语言寻找文件指令,c语言实现文件查找相关推荐

  1. c语言 pragma指令,C语言#pragma指令用法

    引导语:在所有的预处理指令中,#Pragma指令可能是最复杂的了,它的作用是设定编译器的状态或者是指示编译器完成一些特定的动作.以下是百分网小编分享给大家的C语言#pragma指令用法,欢迎阅读! # ...

  2. R语言基础指令和并行算法初识(上篇)

    一.R语言背景介绍 二. R语言基础指令 三. R语言并行算法 四. 计划打算 一.R语言背景介绍 1.2.起源:R是统计领域广泛使用的诞生于1980年左右的S语言的一个分支.可以认为R是S语言的一种 ...

  3. C语言预处理指令大全

    C语言预处理指令 文章目录 C语言预处理指令 define 语法 Linux编译时指定宏的值及宏 删除已有的宏 C语言允许多参数的宏及宏函数 宏函数需要注意的事项 参数宏创建字符串 预处理粘合剂 li ...

  4. c语言控制硬件指令,c语言如何控制硬件

    你们知道在C语言中如何控制计算机的硬件吗?下面是学习啦小编带来的关于c语言如何控制硬件的内容,欢迎阅读! c语言如何控制硬件? C语言是没办法控制硬件的 首先,C语言不能够直接对硬件进行操作.从本质上 ...

  5. c语言编译预处理指令大全,C语言预处理指令

    「今天是学习C语言第 32 天」 当你选择了一种语言,意味着你还选择了一组技术.一个社区.--Joshua Bloch # 预处理 C语言源程序先经过预处理器进行预处理,之后经过编译器编译成二进制可执 ...

  6. c语言open函数打开文件方式,Linux中C语言open函数打开或创建文件详细讲解

    Linux中C语言open函数打开或创建文件详细讲解 Linux中C语言open函数打开或创建文件详细讲解 头文件: #include #include #include 函数原型: int open ...

  7. C语言模块化开发,深入多文件编程

    目录 文章目录 目录 多文件编程 项目分割 避免命名冲突 项目生成的过程 预处理 编译 汇编 链接 语言发展的过程 机器语言 汇编语言 C语言 高级语言 编译的本质 目标文件里藏着什么 可执行文件 链 ...

  8. R语言一次性读入多个csv文件实战:一次导入多个csv形成一个统一的dataframe、原生R方法、readr包、data.table

    R语言一次性读入多个csv文件实战:一次导入多个csv形成一个统一的dataframe.原生R方法.readr包.data.table 目录

  9. R语言dir函数获取目录中文件或者文件夹名称实战

    R语言dir函数获取目录中文件或者文件夹名称实战 目录 R语言dir函数获取目录中文件或者文件夹名称实战 #基本语法

  10. c语言fgetpos的参数,C语言fgetpos()函数:获得当前文件的读写指针(转)

    头文件:#include fgetpos()函数获得当前文件的指针所指的位置,并把该指针所指的位置信息存放到pos所指的对象中.pos以内部格式存储,仅由fgetpos()和fsetpos()使用.f ...

最新文章

  1. sql 分号变成多行_SQL(2)
  2. Android--用手指移动画面里的照片/onTouchEvent事件判断
  3. 在最长的距离二叉树结点
  4. hibernate更新部分字段的几种方法
  5. 淘宝API开发系列--开篇概述
  6. Javascript——声明提升(函数、变量提升)
  7. C++:数字逆向输出
  8. Centos7配置ThinkPHP5.0完整过程(二)
  9. 解决qt调试时Unknown debugger type No Engine
  10. Windows镜像文件下载速度太慢?告诉你个小妙招
  11. 哪个大佬有c#三层架构写的餐饮管理系统源代码
  12. 一款好用的插件——油猴子
  13. java 正则表达式 去掉 文章头部和尾部的空格(全角,半角)、制表符、换页符
  14. SAP License:FI-现金流量表的几种实现方式
  15. 数据分析师之路-数据埋点
  16. Entrust Datacard新一代再转印证卡打印机系列喜获蓝盾杯创新奖
  17. 异构信息网络 Heterogeneous information network (HIN)
  18. react-diagram 序列化Json解读
  19. 17.文件系统磁盘配额
  20. 任何一个做计算机软件的人的梦想:墨绿,我们能做到吗?或者说,什么时候能做到?

热门文章

  1. 【课本】【No.5】大数定律和中心极限定律的理解
  2. 2月14 大数据处理的基本算法
  3. 5G概念被热炒,运营商吃相不要太难看
  4. 从dist到es:发一个NPM库,我蜕了一层皮
  5. 【趣文翻译】如何用各种编程语言杀死一条龙,PHP大亮 [转]
  6. Java- String类概述
  7. 11. 判断是给属性前加typeof 可以同时判断属性是否存在
  8. Git最基本入门,只是个感想总结啊啊啊不要搜到我0.0
  9. babel 无法解析jsx (webpack react )
  10. Exam 70-462 Administering Microsoft SQL Server 2012 Databases 复习帖