C++遍歷文件夾下的所有文件
數(shù)據(jù)分多個(gè)文件存儲,讀取數(shù)據(jù)就需要對多個(gè)文件進(jìn)行操作。首先就需要定位到文件的名字,之后再對文件進(jìn)行相應(yīng)的讀寫操作。多次涉及多文件的讀寫操作,現(xiàn)將這個(gè)實(shí)現(xiàn)總結(jié)一下,方便自己和他人使用。具體代碼如下:
#include "stdafx.h" #include <stdio.h> #include<iostream> #include<vector> #include <Windows.h> #include <fstream> #include <iterator> #include <string> using namespace std; #define MAX_PATH 1024 //最長路徑長度 /*---------------------------- * 功能 : 遞歸遍歷文件夾,找到其中包含的所有文件 *---------------------------- * 函數(shù) : find * 訪問 : public * * 參數(shù) : lpPath [in] 需遍歷的文件夾目錄 * 參數(shù) : fileList [in] 以文件名稱的形式存儲遍歷后的文件 */ void find(char* lpPath,std::vector<const std::string> &fileList) { char szFind[MAX_PATH]; WIN32_FIND_DATA FindFileData; strcpy(szFind,lpPath); strcat(szFind,"\\*.*"); HANDLE hFind=::FindFirstFile(szFind,&FindFileData); if(INVALID_HANDLE_VALUE == hFind) return; while(true) { if(FindFileData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) { if(FindFileData.cFileName[0]!='.') { char szFile[MAX_PATH]; strcpy(szFile,lpPath); strcat(szFile,"\\"); strcat(szFile,(char* )(FindFileData.cFileName)); find(szFile,fileList); } } else { //std::cout << FindFileData.cFileName << std::endl; fileList.push_back(FindFileData.cFileName); } if(!FindNextFile(hFind,&FindFileData)) break; } FindClose(hFind); } int main() { std::vector<const std::string> fileList;//定義一個(gè)存放結(jié)果文件名稱的鏈表 //遍歷一次結(jié)果的所有文件,獲取文件名列表 find("XXXX具體文件夾目錄",fileList);//之后可對文件列表中的文件進(jìn)行相應(yīng)的操作 //輸出文件夾下所有文件的名稱 for(int i = 0; i < fileList.size(); i++) { cout << fileList[i] << endl; } cout << "文件數(shù)目:" << fileList.size() << endl; return 0; }
總結(jié)
以上所述是小編給大家介紹的C++遍歷文件夾下所有文件,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
C++ Boost實(shí)現(xiàn)異步端口掃描器詳解
端口掃描是一種用于識別目標(biāo)系統(tǒng)上哪些網(wǎng)絡(luò)端口處于開放、關(guān)閉或監(jiān)聽狀態(tài)的網(wǎng)絡(luò)活動,本文將運(yùn)用Boost框架實(shí)現(xiàn)一個(gè)基于TCP的掃描工具,有需要的小伙伴可以參考下2023-11-11使用C語言生成圖片的base64編碼的代碼實(shí)現(xiàn)
Base64編碼是一種廣泛使用的編碼方案,將任意二進(jìn)制數(shù)據(jù)轉(zhuǎn)換為可打印的ASCII字符字符串,在實(shí)際應(yīng)用中,Base64編碼常見于電子郵件附件、數(shù)據(jù)庫中存儲非文本數(shù)據(jù)等多種場景,本文將給大家介紹使用C語言生成圖片的base64編碼的代碼實(shí)現(xiàn),需要的朋友可以參考下2024-08-08關(guān)于C++復(fù)制構(gòu)造函數(shù)的實(shí)現(xiàn)講解
今天小編就為大家分享一篇關(guān)于關(guān)于C++復(fù)制構(gòu)造函數(shù)的實(shí)現(xiàn)講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-12-12C語言中關(guān)于庫函數(shù) qsort 的模擬實(shí)現(xiàn)過程
庫函數(shù)的模擬實(shí)現(xiàn)有利于我們?nèi)ド钊肓私膺@個(gè)函數(shù)內(nèi)部是怎樣實(shí)現(xiàn)的,以及學(xué)習(xí)它的算法,使我們更加了解這個(gè)函數(shù)該怎樣去使用,接下來我將詳細(xì)的介紹qsort的應(yīng)用及用法,并且用代碼模擬實(shí)現(xiàn)它們的功能2021-09-09利用C語言實(shí)踐OOP,以及new,delete的深入分析
本篇文章是對用C語言實(shí)踐OOP,new,delete進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05