c++下使用windows api遍歷指定文件夾及其子文件夾中的文件
以下代碼在vs2008中測試通過,利用FindFirstFile,FindNextFile函數(shù)遍歷了我電腦上全路徑為“C:\\Users\\v_tianboli\\Desktop\\windows程式設(shè)計(jì)開發(fā)指南”的文件夾,并輸出文件夾及子文件夾中的所有文件完整路徑到控制臺。完整代碼如下:
#include "stdafx.h" #include <iostream> #include "windows.h" #include <string.h> #include <Strsafe.h> using namespace std; //傳入要遍歷的文件夾路徑,并遍歷相應(yīng)文件夾 void TraverseDirectory(wchar_t Dir[MAX_PATH]) { WIN32_FIND_DATA FindFileData; HANDLE hFind=INVALID_HANDLE_VALUE; wchar_t DirSpec[MAX_PATH]; //定義要遍歷的文件夾的目錄 DWORD dwError; StringCchCopy(DirSpec,MAX_PATH,Dir); StringCchCat(DirSpec,MAX_PATH,TEXT("\\*")); //定義要遍歷的文件夾的完整路徑\* hFind=FindFirstFile(DirSpec,&FindFileData); //找到文件夾中的第一個(gè)文件 if(hFind==INVALID_HANDLE_VALUE) //如果hFind句柄創(chuàng)建失敗,輸出錯(cuò)誤信息 { FindClose(hFind); return; } else { while(FindNextFile(hFind,&FindFileData)!=0) //當(dāng)文件或者文件夾存在時(shí) { if((FindFileData.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)!=0&&wcscmp(FindFileData.cFileName,L".")==0||wcscmp(FindFileData.cFileName,L"..")==0) //判斷是文件夾&&表示為"."||表示為"." { continue; } if((FindFileData.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)!=0) //判斷如果是文件夾 { wchar_t DirAdd[MAX_PATH]; StringCchCopy(DirAdd,MAX_PATH,Dir); StringCchCat(DirAdd,MAX_PATH,TEXT("\\")); StringCchCat(DirAdd,MAX_PATH,FindFileData.cFileName); //拼接得到此文件夾的完整路徑 TraverseDirectory(DirAdd); //實(shí)現(xiàn)遞歸調(diào)用 } if((FindFileData.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)==0) //如果不是文件夾 { wcout<<Dir<<"\\"<<FindFileData.cFileName<<endl; //輸出完整路徑 } } FindClose(hFind); } } int _tmain( int argc, wchar_t *argv[ ], wchar_t *envp[ ] ) { locale loc( "chs" ); //支持中文輸出,否則wchar可能無法輸出值為中文的變量 wcout.imbue( loc ); TraverseDirectory(L"C:\\Users\\v_tianboli\\Desktop\\windows程式設(shè)計(jì)開發(fā)指南"); //遍歷指定的文件夾,此處文件路徑可按具體情況修改 system("pause"); return 0; }
以上代碼在我電腦上運(yùn)行結(jié)果如下:
下面是其他人的補(bǔ)充
C++讀取某個(gè)文件夾下面的子文件夾及其所有文件
_findnext在64位系統(tǒng)操作會(huì)失敗,解決方法是 //文件句柄 long hFile = 0; 需要寫成intptr_t hFile
// TestForOnlyC++.cpp : 定義控制臺應(yīng)用程序的入口點(diǎn)。 // #include "stdafx.h" #include <fstream> #include <iostream> #include <string> #include <sstream> #include <vector> #include<io.h> using namespace std; void getAllFiles(string path, vector<string>& files) { //文件句柄 long hFile = 0; //文件信息 struct _finddata_t fileinfo; //很少用的文件信息讀取結(jié)構(gòu) string p; //string類很有意思的一個(gè)賦值函數(shù):assign(),有很多重載版本 if ((hFile = _findfirst(p.assign(path).append("\\*").c_str(), &fileinfo)) != -1) { do { if ((fileinfo.attrib & _A_SUBDIR)) //判斷是否為文件夾 { if (strcmp(fileinfo.name, ".") != 0 && strcmp(fileinfo.name, "..") != 0) { files.push_back(p.assign(path).append("/").append(fileinfo.name));//保存文件夾名字 getAllFiles(p.assign(path).append("/").append(fileinfo.name), files);//遞歸當(dāng)前文件夾 } } else //文件處理 { files.push_back(p.assign(path).append("/").append(fileinfo.name));//文件名 } } while (_findnext(hFile, &fileinfo) == 0); //尋找下一個(gè),成功返回0,否則-1 _findclose(hFile); } } //測試 int main() { string DATA_DIR = "E:/wangwy/GY/dataForGY/鋼印3/鋼印3"; vector<string> files; //測試 char * DistAll = "AllFiles.txt"; getAllFiles(DATA_DIR, files);//所有文件與文件夾的路徑都輸出 //ofstream ofn(DistAll); //輸出文件流 int size = files.size(); int FaiNum = 0; //ofn << size << endl; cout<< size << endl; for (int i = 0; i<size; i++) { //ofn << files[i] << endl; cout << files[i] << endl; } //ofn.close(); return 0; }
到此這篇關(guān)于c++下使用windows api遍歷指定文件夾及其子文件夾中的文件的文章就介紹到這了,更多相關(guān)c++windows api遍歷指定文件夾內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于VS+QT5應(yīng)用程序換圖標(biāo)的解決方案
這篇文章主要介紹了VS+QT5應(yīng)用程序換圖標(biāo)的處理方案,本文給大家提供了兩種解決方案供大家參考,每種方法給大家講解的都非常詳細(xì),需要的朋友可以參考下2021-12-12VC++實(shí)現(xiàn)程序開機(jī)啟動(dòng)運(yùn)行的方法
這篇文章主要介紹了VC++實(shí)現(xiàn)程序開機(jī)啟動(dòng)運(yùn)行的方法,很實(shí)用的功能,需要的朋友可以參考下2014-08-08C語言中結(jié)構(gòu)體的內(nèi)存對齊規(guī)則講解
C 數(shù)組允許定義可存儲(chǔ)相同類型數(shù)據(jù)項(xiàng)的變量,結(jié)構(gòu)是 C 編程中另一種用戶自定義的可用的數(shù)據(jù)類型,它允許你存儲(chǔ)不同類型的數(shù)據(jù)項(xiàng),本篇讓我們來了解C 的結(jié)構(gòu)體內(nèi)存對齊2022-05-05C++?使用getline()從文件中讀取一行字符串方法示例
這篇文章主要介紹了C++?使用getline()從文件中讀取一行字符串方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09養(yǎng)成良好的C++編程習(xí)慣之內(nèi)存管理的應(yīng)用詳解
"養(yǎng)成良好的編程習(xí)慣"其實(shí)是相當(dāng)綜合的一個(gè)命題,可以從多個(gè)角度、維度和層次進(jìn)行論述和評判,如代碼的風(fēng)格、效率和可讀性;模塊設(shè)計(jì)的靈活性、可擴(kuò)展性和耦合度等等,要試圖把所有方面都闡述清楚必須花很多的精力,而且也不一定能闡述得全面2013-05-05