欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++編程使用findfirst和findnext查找及遍歷文件實現(xiàn)示例

 更新時間:2021年10月16日 10:58:36   作者:ranjiewen  
這篇文章主要為大家介紹了C++編程如何使用findfirst和findnext查找及遍歷文件實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助

這兩個函數(shù)均在io.h里面

一、首先了解一下一個文件結(jié)構(gòu)體:

struct _finddata_t {
    unsigned    attrib;
    time_t      time_create;   
    time_t      time_access;   
    time_t      time_write;
    _fsize_t    size;
    char        name[260];
};

time_t,其實就是long

而_fsize_t,就是unsigned long

現(xiàn)在來解釋一下結(jié)構(gòu)體的數(shù)據(jù)成員吧。

attrib,就是所查找文件的屬性:

_A_ARCH(存檔)、_A_HIDDEN(隱藏)、_A_NORMAL(正常)、

_A_RDONLY(只讀)、 _A_SUBDIR(文件夾)、_A_SYSTEM(系統(tǒng))。

time_create、time_access和time_write分別是創(chuàng)建文件的時間、最后一次訪問文件的時間和文件最后被修改的時間。

size:文件大小

name:文件名。

二、用 _findfirst 和 _findnext 查找文件

1、_findfirst函數(shù):long _findfirst(const char *, struct _finddata_t *);

第一個參數(shù)為文件名,可以用"*.*"來查找所有文件,也可以用"*.cpp"來查找.cpp文件。第二個參數(shù)是_finddata_t結(jié)構(gòu)體指針。若查找成功,返回文件句柄,若失敗,返回-1。

2、_findnext函數(shù):int _findnext(long, struct _finddata_t *);

第一個參數(shù)為文件句柄,第二個參數(shù)同樣為_finddata_t結(jié)構(gòu)體指針。若查找成功,返回0,失敗返回-1。

3、_findclose()函數(shù):int _findclose(long);

只有一個參數(shù),文件句柄。若關(guān)閉成功返回0,失敗返回-1。

#include <io.h>
#include <iostream>
#include <fstream>
using namespace std;
bool transfer(string fileName, int exeNum );
void dfsFolder(string folderPath, ofstream &fout);
int main()
{
    _finddata_t file;
    int k;
    long HANDLE;
    k = HANDLE = _findfirst("*.*", &file);
    while (k != -1)
    {
        cout << file.name << endl;
        k = _findnext(HANDLE, &file);
    }
    _findclose(HANDLE);

    transfer("C:\\Windows\\*.exe", 0);
    ofstream o_fstream;

    dfsFolder("E:\\\WHU\\Study", o_fstream);
    return 0;
}
//_findfirst 函數(shù)返回的是匹配到文件的句柄,數(shù)據(jù)類型為long。
//遍歷過程可以指定文件類型,這通過FileName的賦值來實現(xiàn),例如要遍歷C : \WINDOWS下的所有.exe文件
bool transfer(string fileName , int exeNum)
{
    _finddata_t fileInfo;
    long handle = _findfirst(fileName.c_str(), &fileInfo);

    if (handle == -1L)
    {
        cerr << "failed to transfer files" << endl;
        return false;
    }

    do
    {
        exeNum++;
        cout << fileInfo.name << endl;
    } while (_findnext(handle, &fileInfo) == 0);
    cout << " .exe files' number:  " << exeNum << endl;

    return true;
}

//遍歷文件夾及其子文件夾下所有文件。操作系統(tǒng)中文件夾目錄是樹狀結(jié)構(gòu),使用深度搜索策略遍歷所有文件。用到_A_SUBDIR屬性
//在判斷有無子目錄的if分支中,由于系統(tǒng)在進入一個子目錄時,匹配到的頭兩個文件(夾)是"."(當前目錄),".."(上一層目錄)。
//需要忽略掉這兩種情況。當需要對遍歷到的文件做處理時,在else分支中添加相應的代碼就好
void dfsFolder(string folderPath, ofstream &fout)
{
    _finddata_t FileInfo;
    string strfind = folderPath + "\\*";
    long Handle = _findfirst(strfind.c_str(), &FileInfo);

    if (Handle == -1L)
    {
        cerr << "can not match the folder path" << endl;
        exit(-1);
    }
    do{
        //判斷是否有子目錄  
        if (FileInfo.attrib & _A_SUBDIR)
        {
            //這個語句很重要  
            if ((strcmp(FileInfo.name, ".") != 0) && (strcmp(FileInfo.name, "..") != 0))
            {
                string newPath = folderPath + "\\" + FileInfo.name;
                dfsFolder(newPath, fout);
            }
        }
        else
        {
            fout<<folderPath.c_str() << "\\" << FileInfo.name << " ";
            cout << folderPath.c_str() << "\\" << FileInfo.name << endl;
        }
    } while (_findnext(Handle, &FileInfo) == 0);

    _findclose(Handle);
    fout.close();
}
//#include <iostream>    
//#include <string>    
//#include <io.h>    
//using namespace std;
//
//int main()
//{
//    _finddata_t file;
//    long longf;
//    string tempName;
//    //_findfirst返回的是long型; long __cdecl _findfirst(const char *, struct _finddata_t *)    
//    if ((longf = _findfirst("E:\\WHU\\Study\\*.*", &file)) == -1l)
//    {
//        cout << "文件沒有找到!\n";
//        return 0;
//    }
//    do
//    {
//        cout << "文件列表:\n";
//        tempName = file.name;
//        if (tempName[0] == '.')
//            continue;
//        cout << file.name<<endl;
//
//        if (file.attrib == _A_NORMAL)
//        {
//            cout << "  普通文件  ";
//        }
//        else if (file.attrib == _A_RDONLY)
//        {
//            cout << "  只讀文件  ";
//        }
//        else if (file.attrib == _A_HIDDEN)
//        {
//            cout << "  隱藏文件  ";
//        }
//        else if (file.attrib == _A_SYSTEM)
//        {
//            cout << "  系統(tǒng)文件  ";
//        }
//        else if (file.attrib == _A_SUBDIR)
//        {
//            cout << "  子目錄  ";
//        }
//        else
//        {
//            cout << "  存檔文件  ";
//        }
//        cout << endl;
//    } while (_findnext(longf, &file) == 0);//int __cdecl _findnext(long, struct _finddata_t *);如果找到下個文件的名字成功的話就返回0,否則返回-1   
//
//    _findclose(longf);
//
//    return 0;
//}

以上就是C++編程使用findfirst和findnext查找及遍歷文件實現(xiàn)示例的詳細內(nèi)容,更多關(guān)于findfirst和findnext查找及遍歷文件的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 使用C++的string實現(xiàn)高精度加法運算的實例代碼

    使用C++的string實現(xiàn)高精度加法運算的實例代碼

    下面小編就為大家?guī)硪黄褂肅++的string實現(xiàn)高精度加法運算的實例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • C語言實現(xiàn)哈希搜索算法及原理詳解

    C語言實現(xiàn)哈希搜索算法及原理詳解

    本文主要介紹了C語言實現(xiàn)哈希搜索算法及原理詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • 關(guān)于C語言程序的內(nèi)存分配的入門知識學習

    關(guān)于C語言程序的內(nèi)存分配的入門知識學習

    這篇文章主要介紹了關(guān)于C語言程序的內(nèi)存分配的入門知識學習,特別強調(diào)了堆與棧的內(nèi)存空間申請比較,需要的朋友可以參考下
    2015-12-12
  • 淺談C語言結(jié)構(gòu)體

    淺談C語言結(jié)構(gòu)體

    本文主要介紹C語言 結(jié)構(gòu)體的知識,學習C語言肯定需要學習結(jié)構(gòu)體,這里詳細說明了結(jié)構(gòu)體并附示例代碼,供大家參考學習,有需要的小伙伴可以參考下
    2021-10-10
  • C語言實現(xiàn)簡易訂餐系統(tǒng)

    C語言實現(xiàn)簡易訂餐系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)簡易訂餐系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • C語言在輸入輸出時遇到的常見問題總結(jié)

    C語言在輸入輸出時遇到的常見問題總結(jié)

    大家在平時的做題中是否會遇到和我一樣的煩惱,題目的代碼已經(jīng)基本完成,但是在輸出時候,總是和題目給出的樣例輸出格式不同?,導致題目不能通過。為了解決這一煩惱,我總結(jié)了以下幾點,需要的可以參考一下
    2022-09-09
  • 使用C++一步步實現(xiàn)俄羅斯方塊

    使用C++一步步實現(xiàn)俄羅斯方塊

    本文給大家分享的是作者在使用C++制作俄羅斯方塊的時候的思路分析以及開發(fā)準備和實驗原理,都是些基礎的知識儲備,希望大家能夠喜歡,具體的代碼我們下一節(jié)再分享給大家
    2017-12-12
  • C語言植物大戰(zhàn)數(shù)據(jù)結(jié)構(gòu)二叉樹遞歸

    C語言植物大戰(zhàn)數(shù)據(jù)結(jié)構(gòu)二叉樹遞歸

    這篇文章主要為大家介紹了C語言植物大戰(zhàn)數(shù)據(jù)結(jié)構(gòu)二叉樹遞歸,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • C++順序表的基本操作(使用模版類)

    C++順序表的基本操作(使用模版類)

    這篇文章主要為大家詳細介紹了C++順序表的基本操作,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C++從零配置ffmpeg的詳細過程

    C++從零配置ffmpeg的詳細過程

    本博文源于筆者正在做的任務,將視頻mp4每幀轉(zhuǎn)換成jpg格式,前提是需要配置ffmpeg,因此本文從0下載教讀者如何配置ffmpeg,文中通過圖文結(jié)合的方式給大家介紹得非常詳細,需要的朋友可以參考下
    2024-03-03

最新評論