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

利用C++實現(xiàn)獲取文件夾下所有文件名

 更新時間:2022年09月19日 15:20:15   作者:我不是蕭海哇~~~~  
這篇文章主要為大家詳細(xì)介紹了如何利用C++實現(xiàn)獲取文件夾下所有文件名,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)C++有一定幫助,需要的可以參考一下

查找文件需要一個結(jié)構(gòu)體和幾個函數(shù)。結(jié)構(gòu)體為struct _finddata_t,函數(shù)為_findfirst、findnext和_findclose。

struct _finddata_t

這個結(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[_MAX_FNAME];
};

其中各成員變量的含義如下:

unsigned attrib:

文件屬性的存儲位置。它存儲一個unsigned單元,用于表示文件的屬性。文件屬性是用位表示的,主要有以下一些:

  • _A_ARCH(存檔)
  • _A_HIDDEN(隱藏)
  • _A_NORMAL(正常)
  • _A_RDONLY(只讀)
  • _A_SUBDIR(文件夾)
  • _A_SYSTEM(系統(tǒng))

這些都是在頭文件中定義的宏,可以直接使用,而本身的意義其實是一個無符號整型(只不過這個整型應(yīng)該是2的幾次冪,從而保證只有1位為1,而其它位為0)。既然是位表示,那么當(dāng)一個文件有多個屬性時,它往往是通過位或的方式,來得到幾個屬性的綜合。例如只讀+隱藏+系統(tǒng)屬性,應(yīng)該為:

_A_HIDDEN | _A_RDONLY | _A_SYSTEM

time_t time_create:

這里的time_t是一個變量類型(長整型?相當(dāng)于long int?),用來存儲時間的,我們暫時不用理會,只要知道,這個time_create變量是用來存儲文件創(chuàng)建時間的就可以了。

time_t time_access:

文件最后一個被訪問的時間。

time_t time_write:

文件最后一次被修改的時間。

_fsize_t size:

文件的大小。這里的_fsize_t應(yīng)該相當(dāng)于unsigned整型,表示文件的字節(jié)數(shù)。

char name[_MAX_FNAME]:文件的文件名。這里的_MAX_FNAME是一個常量宏,它在頭文件中被定義,表示的是文件名的最大長度。

前面也說了,這個結(jié)構(gòu)體是用來存儲文件信息的,那么如何把一個硬盤文件的文件信息“存到”這個結(jié)構(gòu)體所表示的內(nèi)存空間去呢?這就要靠_findfirst、_findnext和_fineclose三個函數(shù)的搭配使用了。

下面一一介紹。

long findfirst(char* filespec,struct _finddata_t* fileinfo);

返回值:如果查找成功的話,將返回一個long型的唯一的查找用的句柄(就是一個唯一編號)。這個句柄將在_findnext函數(shù)中被使用。若失敗,則返回-1。

參數(shù):

filespec:標(biāo)明文件的字符串,可支持通配符。比如:*.c,則表示當(dāng)前文件夾下的所有后綴為C的文件。比如:D:\\test\\*,則表示D盤的test文件夾內(nèi)的所有文件。

fileinfo:這里就是用來存放文件信息的結(jié)構(gòu)體的指針。這個結(jié)構(gòu)體必須在調(diào)用此函數(shù)前聲明,不過不用初始化,只要分配了內(nèi)存空間就可以。函數(shù)成功后,函數(shù)會把找到的文件的信息放入這個結(jié)構(gòu)體中。

int _findnext( long handle, struct _finddata_t *fileinfo );

返回值:若成功返回0,否則返回-1。

參數(shù):

handle:即由_findfirst函數(shù)返回回來的句柄。

fileinfo:文件信息結(jié)構(gòu)體的指針。找到文件后,函數(shù)將該文件信息放入此結(jié)構(gòu)體中。

int _findclose( long handle );

返回值:成功返回0,失敗返回-1。

參數(shù):

handle:_findfirst函數(shù)返回回來的句柄。

看到這里,估計都能猜到個大概了吧?先用_findfirst查找第一個文件,若成功則用返回的句柄調(diào)用_findnext函數(shù)查找其它的文件,當(dāng)查找完畢后,用_findclose函數(shù)結(jié)束查找。下面我們就按照這個思路來編寫一個查找工程目錄下的sam文件夾內(nèi)的所有文件,并輸出文件名。

 /*
  @author:CodingMengmeng
  @theme:獲取指定文件夾下的所有文件名
  @time:2017-1-13 11:46:22
  @blog:http://www.cnblogs.com/codingmengmeng/
 */
#include <io.h>  
#include <iostream>  
#include <vector>  
using namespace std;
 
void getFiles(string path, vector<string>& files)
 {
     //文件句柄  
     long   hFile = 0;
     //文件信息,聲明一個存儲文件信息的結(jié)構(gòu)體  
     struct _finddata_t fileinfo;
     string p;//字符串,存放路徑
     if ((hFile = _findfirst(p.assign(path).append("\\*").c_str(), &fileinfo)) != -1)//若查找成功,則進入
     {
         do
         {
             //如果是目錄,迭代之(即文件夾內(nèi)還有文件夾)  
             if ((fileinfo.attrib &  _A_SUBDIR))
             {
                 //文件名不等于"."&&文件名不等于".."
                 //.表示當(dāng)前目錄
                 //..表示當(dāng)前目錄的父目錄
                 //判斷時,兩者都要忽略,不然就無限遞歸跳不出去了!
                 if (strcmp(fileinfo.name, ".") != 0 && strcmp(fileinfo.name, "..") != 0)
                    getFiles(p.assign(path).append("\\").append(fileinfo.name), files);
            }
             //如果不是,加入列表  
             else
             {
                 files.push_back(p.assign(path).append("\\").append(fileinfo.name));
             }
         } while (_findnext(hFile, &fileinfo) == 0);
         //_findclose函數(shù)結(jié)束查找
         _findclose(hFile);
     }
 }
 
 
 int main(){
     char * filePath = "sam";//自己設(shè)置目錄  
     vector<string> files;
 
     獲取該路徑下的所有文件  
     getFiles(filePath, files);
 
     char str[30];
     int size = files.size();
     for (int i = 0; i < size; i++)
     {
         cout << files[i].c_str() << endl;
     }
 }

運行結(jié)果:

到此這篇關(guān)于利用C++實現(xiàn)獲取文件夾下所有文件名的文章就介紹到這了,更多相關(guān)C++獲取文件名內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言循環(huán)隊列與用隊列實現(xiàn)棧問題解析

    C語言循環(huán)隊列與用隊列實現(xiàn)棧問題解析

    循環(huán)隊列又叫環(huán)形隊列,是一種特殊的隊列。循環(huán)隊列解決了隊列出隊時需要將所有數(shù)據(jù)前移一位的問題,本篇帶你一起看看循環(huán)隊列的問題和怎樣用隊列實現(xiàn)棧
    2022-04-04
  • C/C++?Qt?TabWidget?實現(xiàn)多窗體創(chuàng)建詳解

    C/C++?Qt?TabWidget?實現(xiàn)多窗體創(chuàng)建詳解

    TabWidget組件配合自定義Dialog組件,可實現(xiàn)一個復(fù)雜的多窗體分頁結(jié)構(gòu)。這篇文章就主要介紹了如何通過TabWidget實現(xiàn)多窗體的創(chuàng)建,感興趣的小伙伴可以了解一下
    2021-12-12
  • C語言實現(xiàn)頁面置換算法

    C語言實現(xiàn)頁面置換算法

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)頁面置換算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • C++回溯算法深度優(yōu)先搜索舉例分析

    C++回溯算法深度優(yōu)先搜索舉例分析

    回溯在迷宮搜索中使用很常見,就是這條路走不通,然后返回前一個路口,繼續(xù)下一條路。回溯算法說白了就是窮舉法,下面讓我們一起來看看回溯算法深度優(yōu)先搜索吧
    2022-03-03
  • C語言基于圖形庫實現(xiàn)雙人貪吃蛇

    C語言基于圖形庫實現(xiàn)雙人貪吃蛇

    這篇文章主要為大家詳細(xì)介紹了C語言基于圖形庫實現(xiàn)雙人貪吃蛇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C/C++實現(xiàn)捕獲所有信號的示例詳解

    C/C++實現(xiàn)捕獲所有信號的示例詳解

    Linux的信號機制大部分情況下用不到,但是由于大部分信號的默認(rèn)處理是終止進程,不正確處理會惹麻煩,所以我們來看看如何使用C/C++實現(xiàn)捕獲所有信號吧
    2024-03-03
  • C語言中的程序環(huán)境與預(yù)處理詳情

    C語言中的程序環(huán)境與預(yù)處理詳情

    這篇文章主要介紹了C語言中的程序環(huán)境與預(yù)處理詳情,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-07-07
  • C++深復(fù)制和淺復(fù)制講解

    C++深復(fù)制和淺復(fù)制講解

    這篇文章主要介紹了C++深復(fù)制和淺復(fù)制講解,C++中深復(fù)制和淺復(fù)制最大的區(qū)別在“類包含指針類型的數(shù)據(jù)成員”時,下面感興趣的小伙伴和小編一起進入文章了解更多相關(guān)內(nèi)容吧
    2022-03-03
  • VC++在TXT文件指定位置追加內(nèi)容的方法

    VC++在TXT文件指定位置追加內(nèi)容的方法

    這篇文章主要介紹了VC++在TXT文件指定位置追加內(nèi)容的方法,功能較為實用,需要的朋友可以參考下
    2014-08-08
  • Qt連接數(shù)據(jù)庫并實現(xiàn)數(shù)據(jù)庫增刪改查的圖文教程

    Qt連接數(shù)據(jù)庫并實現(xiàn)數(shù)據(jù)庫增刪改查的圖文教程

    QT連接數(shù)據(jù)庫是應(yīng)用開發(fā)的常用基礎(chǔ)操作,經(jīng)過實驗我總結(jié)了一些例程,下面這篇文章主要給大家介紹了關(guān)于Qt連接數(shù)據(jù)庫并實現(xiàn)數(shù)據(jù)庫增刪改查的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04

最新評論