C/C++實(shí)現(xiàn)遍歷文件夾最全方法總結(jié)
一、filesystem(推薦)
在c++17中,引入了文件系統(tǒng),使用起來(lái)非常方便
在VS中,可以直接在項(xiàng)目屬性中調(diào)整:

只要是C++17即以上都可
然后頭文件:
#include<filesystem>
使用的類(lèi):
directory_iterator
注意:filesystem在std命名空間中,而directory_iterator在filesystem命名空間中
所以如果想要直接使用,你就得這樣寫(xiě):
std::filesystem::directory_iterator
使用方法很簡(jiǎn)單,比如我要遍歷C盤(pán):
#include<iostream>
#include<filesystem>
using namespace std;
int main() {
for (auto& i : filesystem::directory_iterator("C:\\")) {
cout << i.path().string()<< endl;
}
}
這里通過(guò)直接傳入路徑C:\\, 直接構(gòu)造一個(gè)匿名directory_iterator類(lèi)的對(duì)象
filesystem::directory_iterator("C:\\")
然后用for循環(huán)挨個(gè)取出該類(lèi)的所有元素即可(看類(lèi)名,猜測(cè)其應(yīng)該使用的是迭代器在遍歷)
該類(lèi)中的元素為directory_entry類(lèi)的對(duì)象,其下有很多我們常用的操作函數(shù),比如判斷其是否為目錄,文件大小等等
最常用的肯定就是文件路徑,可以通過(guò)path函數(shù)返回一個(gè)路徑對(duì)象,即path類(lèi)
i.path()
這個(gè)類(lèi)又可以對(duì)該路徑進(jìn)行很多操作,比如獲取文件擴(kuò)展名,獲取文件名,獲取根路徑等等
我這里直接調(diào)用string函數(shù),就可以返回路徑字符串
是不是相當(dāng)?shù)姆奖?
二、io.h
在文件系統(tǒng)引入前,很多時(shí)候我們不得不依靠C語(yǔ)言的庫(kù)函數(shù)實(shí)現(xiàn)遍歷文件夾,io.h這個(gè)庫(kù)就是包含了遍歷文件夾的相關(guān)函數(shù)
從它的使用方法來(lái)看,基本就是將win api的文件夾遍歷函數(shù)簡(jiǎn)單的封裝了一下:
#include<iostream>
#include<io.h>
using namespace std;
int main() {
_finddata64i32_t fileInfo;
intptr_t hFile=_findfirst("C:\\*",&fileInfo);
if (hFile == -1) {
return -1;
}
do
{
cout << fileInfo.name << endl;
} while (_findnext(hFile,&fileInfo)==0);
}
首先調(diào)用_findfirst函數(shù),其第一個(gè)參數(shù)為遍歷的文件夾路徑,注意路徑最后,需要添加通配符
intptr_t hFile=_findfirst("C:\\*",&fileInfo);
比如我這里遍歷C盤(pán)下的所有文件,就在路徑后面添加了*,代表任意文件
如果失敗,返回-1,否則,就會(huì)返回文件句柄,并且將找到的第一個(gè)文件信息放在_finddata64i32_t結(jié)構(gòu)體變量中
定義如下:
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];
};然后我們就可以通過(guò)do{}while循環(huán),遍歷所有文件
注意_findnext函數(shù):
_findnext(hFile,&fileInfo)==0
其第一個(gè)參數(shù)就是_findfirst函數(shù)的返回值,第二個(gè)參數(shù)同樣是文件信息結(jié)構(gòu)體
只要找到了下一個(gè),就會(huì)返回0,直到找不到了,返回-1,結(jié)束循環(huán)
三、win API
使用方法與上面的io.h幾乎一模一樣
#include<iostream>
#include<Windows.h>
using namespace std;
int main() {
WIN32_FIND_DATAA fileInfo;
HANDLE hFile=FindFirstFileA("C:\\*",&fileInfo);
if (hFile == INVALID_HANDLE_VALUE) {
return -1;
}
do
{
cout << fileInfo.cFileName << endl;
} while (FindNextFileA(hFile,&fileInfo));
}
只有幾個(gè)不同點(diǎn):
1.首先文件信息結(jié)構(gòu)體更加詳細(xì),但也更難用
typedef struct _WIN32_FIND_DATAA {
DWORD dwFileAttributes;
FILETIME ftCreationTime;
FILETIME ftLastAccessTime;
FILETIME ftLastWriteTime;
DWORD nFileSizeHigh;
DWORD nFileSizeLow;
DWORD dwReserved0;
DWORD dwReserved1;
_Field_z_ CHAR cFileName[ MAX_PATH ];
_Field_z_ CHAR cAlternateFileName[ 14 ];
#ifdef _MAC
DWORD dwFileType;
DWORD dwCreatorType;
WORD wFinderFlags;
#endif
} WIN32_FIND_DATAA, *PWIN32_FIND_DATAA, *LPWIN32_FIND_DATAA;
2.FindFirstFileA的返回值為HANDLE ,即句柄,與宏INVALID_HANDLE_VALUE進(jìn)行比較,相等則說(shuō)明失敗,這個(gè)宏實(shí)際上就是-1
3.FindNextFileA的返回值為true則匹配成功,為false則匹配失敗,直接退出循環(huán)
到此這篇關(guān)于C/C++實(shí)現(xiàn)遍歷文件夾最全方法總結(jié)的文章就介紹到這了,更多相關(guān)C/C++遍歷文件夾內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
簡(jiǎn)單了解C語(yǔ)言中直接插入排序與直接選擇排序?qū)崿F(xiàn)
這篇文章主要介紹了C語(yǔ)言中直接插入排序與直接選擇排序?qū)崿F(xiàn),插入排序的基本操作就是將一個(gè)數(shù)據(jù)插入到已經(jīng)排好序的有序數(shù)據(jù)中,從而得到一個(gè)新的、個(gè)數(shù)加一的有序數(shù)據(jù),需要的朋友可以參考下2016-03-03
VS2019+MPI配置過(guò)程的實(shí)現(xiàn)步驟
本文介紹了在VS2019上配置MPI,包括下載和安裝MPI、創(chuàng)建項(xiàng)目、配置屬性、導(dǎo)入頭文件和庫(kù)文件、添加依賴項(xiàng)等步驟,具有一定的參考價(jià)值,感興趣的可以了解一下2024-12-12
Linux搭建C++開(kāi)發(fā)調(diào)試環(huán)境的方法步驟
這篇文章主要介紹了Linux搭建C++開(kāi)發(fā)調(diào)試環(huán)境的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10
淺析Boost智能指針:scoped_ptr shared_ptr weak_ptr
雖然通過(guò)弱引用指針可以有效的解除循環(huán)引用,但這種方式必須在程序員能預(yù)見(jiàn)會(huì)出現(xiàn)循環(huán)引用的情況下才能使用,也可以是說(shuō)這個(gè)僅僅是一種編譯期的解決方案,如果程序在運(yùn)行過(guò)程中出現(xiàn)了循環(huán)引用,還是會(huì)造成內(nèi)存泄漏的2013-09-09
C++ LeetCode1780判斷數(shù)字是否可以表示成三的冪的和
這篇文章主要為大家介紹了C++ LeetCode1780判斷數(shù)字是否可以表示成三的冪的和題解示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
C++簡(jiǎn)明分析臨時(shí)對(duì)象是什么
對(duì)性能來(lái)說(shuō),許多的問(wèn)題都需要和出現(xiàn)頻率及本身執(zhí)行一次的開(kāi)銷(xiāo)掛鉤,有些問(wèn)題雖然看似比較開(kāi)銷(xiāo)較大,但是很少會(huì)執(zhí)行到,那也不會(huì)對(duì)程序有大的影響;同樣一個(gè)很小開(kāi)銷(xiāo)的函數(shù)執(zhí)行很頻繁,同樣會(huì)對(duì)程序的執(zhí)行效率有很大影響。本章中作者主要根據(jù)臨時(shí)對(duì)象來(lái)闡述這樣一個(gè)觀點(diǎn)2022-04-04
C++中cin.getline()和getline()函數(shù)的區(qū)別小結(jié)
這篇文章主要介紹了C++中cin.getline()和getline()函數(shù)區(qū)別的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03

