• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 224  文章 - 41  trackbacks - 0
            <2011年5月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            享受編程

            常用鏈接

            留言簿(11)

            隨筆分類(159)

            隨筆檔案(224)

            文章分類(2)

            文章檔案(4)

            經典c++博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            原文地址:http://blog.csdn.net/zhangzuohai/archive/2009/06/19/4282117.aspx
            遍歷所有的文件和文件夾并對文件進行操作。

            #include "stdlib.h"   #include "direct.h"   #include "string.h"   #include "io.h"   #include "stdio.h"    #include "iostream.h"     class CBrowseDir   {   protected:       //存放初始目錄的絕對路徑,以'\'結尾       char m_szInitDir[_MAX_PATH];          public:       //缺省構造器       CBrowseDir();              //設置初始目錄為dir,如果返回false,表示目錄不可用       bool SetInitDir(const char *dir);              //開始遍歷初始目錄及其子目錄下由filespec指定類型的文件       //filespec可以使用通配符 * ?,不能包含路徑。       //如果返回false,表示遍歷過程被用戶中止       bool BeginBrowse(const char *filespec);          protected:       //遍歷目錄dir下由filespec指定的文件       //對于子目錄,采用迭代的方法       //如果返回false,表示中止遍歷文件       bool BrowseDir(const char *dir,const char *filespec);              //函數BrowseDir每找到一個文件,就調用ProcessFile       //并把文件名作為參數傳遞過去       //如果返回false,表示中止遍歷文件       //用戶可以覆寫該函數,加入自己的處理代碼       virtual bool ProcessFile(const char *filename);              //函數BrowseDir每進入一個目錄,就調用ProcessDir       //并把正在處理的目錄名及上一級目錄名作為參數傳遞過去       //如果正在處理的是初始目錄,則parentdir=NULL       //用戶可以覆寫該函數,加入自己的處理代碼       //比如用戶可以在這里統計子目錄的個數       virtual void ProcessDir(const char *currentdir,const char *parentdir);   };     CBrowseDir::CBrowseDir()   {       //用當前目錄初始化m_szInitDir       getcwd(m_szInitDir,_MAX_PATH);              //如果目錄的最后一個字母不是'\',則在最后加上一個'\'       int len=strlen(m_szInitDir);       if (m_szInitDir[len-1] != '\\')           strcat(m_szInitDir,"\\");   }     bool CBrowseDir::SetInitDir(const char *dir)   {       //先把dir轉換為絕對路徑       if (_fullpath(m_szInitDir,dir,_MAX_PATH) == NULL)           return false;              //判斷目錄是否存在       if (_chdir(m_szInitDir) != 0)           return false;              //如果目錄的最后一個字母不是'\',則在最后加上一個'\'       int len=strlen(m_szInitDir);       if (m_szInitDir[len-1] != '\\')           strcat(m_szInitDir,"\\");              return true;   }     bool CBrowseDir::BeginBrowse(const char *filespec)   {       ProcessDir(m_szInitDir,NULL);       return BrowseDir(m_szInitDir,filespec);   }     bool CBrowseDir::BrowseDir(const char *dir,const char *filespec)   {       _chdir(dir);              //首先查找dir中符合要求的文件       long hFile;       _finddata_t fileinfo;       if ((hFile=_findfirst(filespec,&fileinfo)) != -1)       {           do          {               //檢查是不是目錄               //如果不是,則進行處理               if (!(fileinfo.attrib & _A_SUBDIR))               {                   char filename[_MAX_PATH];                   strcpy(filename,dir);                   strcat(filename,fileinfo.name);                   cout << filename << endl;                   if (!ProcessFile(filename))                       return false;               }           } while (_findnext(hFile,&fileinfo) == 0);           _findclose(hFile);       }       //查找dir中的子目錄       //因為在處理dir中的文件時,派生類的ProcessFile有可能改變了       //當前目錄,因此還要重新設置當前目錄為dir。       //執行過_findfirst后,可能系統記錄下了相關信息,因此改變目錄       //對_findnext沒有影響。       _chdir(dir);       if ((hFile=_findfirst("*.*",&fileinfo)) != -1)       {           do          {               //檢查是不是目錄               //如果是,再檢查是不是 . 或 ..                //如果不是,進行迭代               if ((fileinfo.attrib & _A_SUBDIR))               {                   if (strcmp(fileinfo.name,".") != 0 && strcmp                       (fileinfo.name,"..") != 0)                   {                       char subdir[_MAX_PATH];                       strcpy(subdir,dir);                       strcat(subdir,fileinfo.name);                       strcat(subdir,"\\");                       ProcessDir(subdir,dir);                       if (!BrowseDir(subdir,filespec))                           return false;                   }               }           } while (_findnext(hFile,&fileinfo) == 0);           _findclose(hFile);       }       return true;   }     bool CBrowseDir::ProcessFile(const char *filename)   {       return true;   }     void CBrowseDir::ProcessDir(const char                                *currentdir,const char *parentdir)   {   }     //從CBrowseDir派生出的子類,用來統計目錄中的文件及子目錄個數   class CStatDir:public CBrowseDir   {   protected:       int m_nFileCount;   //保存文件個數       int m_nSubdirCount; //保存子目錄個數          public:       //缺省構造器       CStatDir()       {           //初始化數據成員m_nFileCount和m_nSubdirCount           m_nFileCount=m_nSubdirCount=0;       }              //返回文件個數       int GetFileCount()       {           return m_nFileCount;       }              //返回子目錄個數       int GetSubdirCount()       {           //因為進入初始目錄時,也會調用函數ProcessDir,           //所以減1后才是真正的子目錄個數。           return m_nSubdirCount-1;       }          protected:       //覆寫虛函數ProcessFile,每調用一次,文件個數加1       virtual bool ProcessFile(const char *filename)       {           m_nFileCount++;           return CBrowseDir::ProcessFile(filename);       }              //覆寫虛函數ProcessDir,每調用一次,子目錄個數加1       virtual void ProcessDir           (const char *currentdir,const char *parentdir)       {           m_nSubdirCount++;           CBrowseDir::ProcessDir(currentdir,parentdir);       }   };     void main()   {       //獲取目錄名       char buf[256];       printf("請輸入要統計的目錄名:");       gets(buf);              //構造類對象       CStatDir statdir;              //設置要遍歷的目錄       if (!statdir.SetInitDir(buf))       {           puts("目錄不存在。");           return;       }              //開始遍歷       statdir.BeginBrowse("*.*");       printf("文件總數: %d\n子目錄總數:%d\n",statdir.GetFileCount(),statdir.GetSubdirCount());   }   

            本文來自CSDN博客,轉載請標明出處:http:
            //blog.csdn.net/zhangzuohai/archive/2009/06/19/4282117.aspx

            相關函數的解釋
            --------------------------------------------------------------------------------
            _fullpath(char*abspath,char* relpath,size_t maxsize);
            參數解釋

            absPath
            Pointer to a buffer containing the absolute or full path name, or NULL.

            relPath
            Relative path name.

            maxLength
            Maximum length of the absolute path name buffer (absPath ). This length is in bytes for _fullpath but in wide characters (wchar_t ) for _wfullpath .

            返回值
            Each of these functions returns a pointer to a buffer containing the absolute path name (absPath ). If there is an error (for example, if the value passed in relPath includes a drive letter that is not valid or cannot be found, or if the length of the created absolute path name (absPath ) is greater than maxLength ), the function returns NULL .

              Remarks

            The _fullpath function expands the relative path name in relPath to its fully qualified or absolute path and stores this name in absPath . If absPath is NULL, malloc is used to allocate a buffer of sufficient length to hold the path name. It is the responsibility of the caller to free this buffer. A relative path name specifies a path to another location from the current location (such as the current working directory: "."). An absolute path name is the expansion of a relative path name that states the entire path required to reach the desired location from the root of the file system. Unlike _makepath , _fullpath can be used to obtain the absolute path name for relative paths (relPath ) that include "./" or "../" in their names.

            For example, to use C run-time routines, the application must include the header files that contain the declarations for the routines. Each header file include statement references the location of the file in a relative manner (from the application's working directory):

            --------------------------------------------------------------------------------
            改變當前的工作目錄到指定的目錄中
            _chdir, _wchdir
            Changes the current working directory.

            int _chdir(
               const char *dirname
            );
            int _wchdir(
               const wchar_t *dirname
            );Parameters
            dirname
            Path of new working directory.

              Return Value
            These functions return a value of 0 if successful. A return value of –1 indicates failure. If the specified path could not be found, errno is set to ENOENT . If dirname is NULL, the invalid parameter handler is invoked, as described in Parameter Validation . If execution is allowed to continue, errno is set to EINVAL and the function returns -1.

              Remarks

            The _chdir function changes the current working directory to the directory specified by dirname . The dirname parameter must refer to an existing directory. This function can change the current working directory on any drive. If a new drive letter is specified in dirname , the default drive letter is changed as well. For example, if A is the default drive letter and \BIN is the current working directory, the following call changes the current working directory for drive C and establishes C as the new default drive:

            代碼

            posted on 2009-12-13 14:40 漂漂 閱讀(1087) 評論(0)  編輯 收藏 引用
            99久久精品免费观看国产| 青青草原综合久久大伊人| 国产精品一区二区久久| 国产国产成人久久精品| 麻豆精品久久久久久久99蜜桃| 久久国产色av免费看| 91精品国产综合久久四虎久久无码一级 | 亚洲精品97久久中文字幕无码| 一级a性色生活片久久无| 一本久久a久久精品亚洲| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久久久亚洲AV无码专区首JN | 国产精品久久久久久久app| 久久综合狠狠综合久久综合88| 久久成人精品视频| 日韩欧美亚洲综合久久| 精品久久久久久国产| 蜜桃麻豆WWW久久囤产精品| 精品人妻伦九区久久AAA片69| 超级97碰碰碰碰久久久久最新| 久久精品国产一区二区三区日韩| 色99久久久久高潮综合影院| 国产精品99久久免费观看| 青青草国产97免久久费观看| 狠狠久久亚洲欧美专区| 久久精品国产2020| 久久受www免费人成_看片中文| 2020最新久久久视精品爱| 久久国产精品无码HDAV| 无码人妻久久一区二区三区蜜桃 | 国产亚洲精久久久久久无码AV| 狠狠色婷婷久久综合频道日韩| 久久亚洲高清综合| 久久久久人妻精品一区三寸蜜桃 | 中文字幕热久久久久久久| 亚洲人成无码网站久久99热国产 | 色婷婷综合久久久中文字幕| 久久久久久免费视频| 婷婷久久五月天| 国产精品久久新婚兰兰 | 亚洲狠狠综合久久|