C++ 遍历文件

/* 文件名:searchAllFile.cpp
 * int searchAllFile(string filePath, //要搜索的文件路径
 * int layer //layer==0 //搜索的层次,输入路径的层次应该为0
 * string fileNameToSave); //存储文件信息的文件名,包括路径
 *
 *
 *
 *
 *
 *
 * <io.h>中定义了结构体 struct _finddata64i32_t (C风格),用来存储文件的各种信息
 *详细如下:
 *struct _finddata64i32_t 
 * {
 * unsigned attrib;
 * __time64_t time_create; // -1 for FAT file systems 
 * __time64_t time_access; // -1 for FAT file systems 
 * __time64_t time_write;
 * _fsize_t size;
 * char name[260];
 * };
 *各参数意义如下:
 *unsigned attrib :4个字节,存储文件的属性
 * _A_ARCH (存档) 0x20 
 * _A_SUBDIR(文件夹)0x10
 * _A_SYSTEM(系统)0x04
 * _A_HIDDEN(隐藏)0x02
 * _A_RDONLY(只读)0x01
 * _A_NORMAL(正常)0X00
 *这些都是<io.h>中定义的宏,每一个都是一个unsigned int,各属性叠加时进行或运算,如_A_HIDDEN|_A_RDONLY
 *
 *__time64_t time_create: 文件创建的时间
 *__time64_t time_access: 文件最后一次访问的时间
 *__time64_t time_write: 文件最后以此修改的时间
 *_fsize_t size: 文件的大小,字节为单位
 *char name[260]: 文件名
 *
 *--------------------------------------------------------------------------------------------------------------------------------
 *<io.h> 中定义了两个函数
 *long _findfirst64i32(const char * _Filename,struct _finddata64i32_t * _FindData); ,查找第一个_Filename的信息,存储到结构体_FindData中             
 * 查找成功,返回一个用于继续查找的句柄(一个唯一的编号)
 * 查找 失败,返回-1 
 *int _findnext64i32(long handle,struct _finddata64i32_t *fileinfo) ; 根据句柄handle查找下一个文件,存放在 fileinfo中
 * 查找成功,返回0,失败返回-1
 *ing _findclose(long handle); 关闭句柄handle,成功返回0,失败返回-1
 *---------------------------------------------------------------------------------------------------------------------------------------
 */
#include<iostream> 
#include<string> 
#include<fstream>
#include<io.h> //定义了结构体struct _finddata64i32_t(该结构体包含文件的相关属性,如文件名,文件的属性等
    //定义函数: long _findfirst64i32(char* fileName,struct _finddata64i32_t *fileinf0);
    //定义函数: int _findnext64i32(long handle,struct _finddata64i32_t *fileinfo);
    //定义函数: int _findclose(long handle);
using namespace std; 
//定义链表结点
struct fileInfoNode
{
 struct _finddata64i32_t fileInfo; //保存文件信息的结构体
 string fileName;
 struct fileInfoNode* left;
};
//把文件信息连接到链表head中
int saveToLink(struct fileInfoNode*& head, //链表的头结点,引用参量
 const string& fileName, //IN:文件名(包括路径)
 const struct _finddata64i32_t& fileInfo) //IN:文件信息结构体,引用参量
{
 //建立一个结点
  fileInfoNode* p;
  p=new fileInfoNode;
  p->fileInfo=fileInfo; //把传入的文件信息复制进结点
  p->fileName=fileName;
  p->left=head;
  head=p;
  return 0;
}
//显示整个查找到的文件的信息
void displayLink(struct fileInfoNode* head)//IN:头结点,值传递参数
{
 while(head!=NULL)
 {
  cout<<"fileName: "<<head->fileName<<endl;
  cout<<"fileSize: "<<dec<<head->fileInfo.size<<"字节"<<endl;
  cout<<"fileAttrib: "<<"0x"<<hex<<head->fileInfo.attrib<<endl;
  cout<<"-------------------------------------------------------------------------------------------"<<endl;
  head=head->left;
 }
}
//把文件信息存储到文件 fileName 中
void saveLinkToFile(struct fileInfoNode* head,string saveFileName,int counter)
{
 ofstream fout;
 //打开文件
 fout.open(saveFileName.c_str());
 if((fout.is_open())==false)
 {
  cout<<"存储文件打开失败!"<<endl;
  exit(-1);
 }
 fout<<"the file number is: "<<counter<<endl;
 fout<<"-------------------------------------------------------------------------------------------------------"<<endl;
 while(head!=NULL)
 {
  fout<<"fileName: "<<head->fileName<<endl;
  fout<<"fileSize: "<<dec<<head->fileInfo.size<<"字节"<<endl;
  fout<<"fileAttrib: "<<"0x"<<hex<<head->fileInfo.attrib<<endl;
  fout<<"-------------------------------------------------------------------------------------------------------"<<endl;
  head=head->left;
 }
 //关闭文件
 fout.close();
}
//
int searchAllFile(string filePath,//IN:文件所在的路径,如:f:\example
 int layer,//层次,只有层次为0时,才完成链表中文件信息的显示和存储
   string fileInfoOut) //IN:存储的文件名
{
 struct _finddata64i32_t fileInfo;//保存文件信息的结构体
 static fileInfoNode* head=NULL; //fileInfoNode链表的头结点,静态存储
 static int counter=0; //记录文件数目
 long handle;//句柄
 int done;//查找nextfile是否成功
 string fileName=filePath+"\\*.*"; //要搜索的文件名
 //查找第一个文件,返回句柄
 handle=_findfirst64i32(fileName.c_str(),&fileInfo);
 if(handle==-1)
 {
  cout<<"该目录为空!"<<endl;
  //cin.get();
   return -1;
 }
 do
 {
 // cout<<"查找成功"<<endl;
 // cin.get();
 // cout<<fileInfo.name<<endl;
  //如果是文件夹".",或者"..",则进行判断下一个文件
  if((strcmp(fileInfo.name,".")==0)|(strcmp(fileInfo.name,"..")==0))
  {
   //cout<<"丢弃!"<<endl;
   //cin.get();
   continue;
  }
  //如果是文件夹,则进入下一层文件夹搜索
  if((fileInfo.attrib&_A_SUBDIR)==_A_SUBDIR)
  {
 // cout<<"是文件夹"<<endl;
 // cin.get();
   string filePathSub=filePath+"\\"+fileInfo.name;
   //递归调用
   searchAllFile(filePathSub,++layer,fileInfoOut);
   layer--;
  }
  //把搜集到的信息连接到文件
  else
  {
// cout<<"是文件,存储信息!"<<endl;
// cin.get();
   counter++;
   string fileNameTure=filePath+"\\"+fileInfo.name;
   saveToLink(head,fileNameTure,fileInfo); //存储到链表中
  }
 }while(!(done=_findnext64i32(handle,&fileInfo)));
 _findclose(handle);
 //layer==时,完成链表的存储
 if(layer==0)
 {
  //显示链表中的内容
   displayLink(head);
  //存储链表中的内容
   saveLinkToFile(head,fileInfoOut,counter);
 }
 return 0;
}

本文来自:http://blog.chinaunix.net/uid-25808509-id-3239453.html

posted @ 2013-09-27 16:31  zxwAAA  阅读(567)  评论(0编辑  收藏  举报