zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    获取全部 txt 文本中出现次数最多的前N个词汇
    提取txt文本有效内容
    部分画图
    Series结构(常用)
    C 语言实例
    HTML之marquee(文字滚动)详解
    一款好看的404页面代码 | 滚动的404
    VS2010到VS2019各个版本的密钥
    什么是工程/项目?
    什么是IDE(集成开发环境)?
  • 原文地址:https://www.cnblogs.com/zxwAAA/p/3342985.html
Copyright © 2011-2022 走看看