溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

c++下怎么使用windows api遍歷指定文件夾及其子文件夾中的文件

發(fā)布時間:2021-07-28 09:04:27 來源:億速云 閱讀:178 作者:chen 欄目:開發(fā)技術

這篇文章主要介紹“c++下怎么使用windows api遍歷指定文件夾及其子文件夾中的文件”,在日常操作中,相信很多人在c++下怎么使用windows api遍歷指定文件夾及其子文件夾中的文件問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”c++下怎么使用windows api遍歷指定文件夾及其子文件夾中的文件”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

以下代碼在vs2008中測試通過,利用FindFirstFile,FindNextFile函數(shù)遍歷了我電腦上全路徑為“C:\\Users\\v_tianboli\\Desktop\\windows程式設計開發(fā)指南”的文件夾,并輸出文件夾及子文件夾中的所有文件完整路徑到控制臺。完整代碼如下:

#include "stdafx.h"
#include <iostream>
#include "windows.h"
#include <string.h>
#include <Strsafe.h>
using namespace std;
 
//傳入要遍歷的文件夾路徑,并遍歷相應文件夾
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);          //找到文件夾中的第一個文件
 
	if(hFind==INVALID_HANDLE_VALUE)                               //如果hFind句柄創(chuàng)建失敗,輸出錯誤信息
	{
		FindClose(hFind); 
		return;  
	}
	else 
	{
		while(FindNextFile(hFind,&FindFileData)!=0)                            //當文件或者文件夾存在時
		{
			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);                                  //實現(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程式設計開發(fā)指南");         //遍歷指定的文件夾,此處文件路徑可按具體情況修改
	system("pause");
	return 0;
}

以上代碼在我電腦上運行結果如下:

c++下怎么使用windows api遍歷指定文件夾及其子文件夾中的文件

下面是其他人的補充

C++讀取某個文件夾下面的子文件夾及其所有文件

_findnext在64位系統(tǒng)操作會失敗,解決方法是 //文件句柄 long hFile = 0; 需要寫成intptr_t hFile

// TestForOnlyC++.cpp : 定義控制臺應用程序的入口點。
//

#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;  //很少用的文件信息讀取結構
	string p;  //string類很有意思的一個賦值函數(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);//遞歸當前文件夾
				}
			}
			else    //文件處理
			{
				files.push_back(p.assign(path).append("/").append(fileinfo.name));//文件名
			}
		} while (_findnext(hFile, &fileinfo) == 0);  //尋找下一個,成功返回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;
}

到此,關于“c++下怎么使用windows api遍歷指定文件夾及其子文件夾中的文件”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI