C++從一個(gè)文件夾中讀出所有txt文件的方法示例
前言
前段時(shí)間做項(xiàng)目需要讀取一個(gè)文件夾里面所有的txt文件,查詢資料后得到以下實(shí)現(xiàn)方法:
首先了解一下這個(gè)結(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[260]; };
其中各成員變量的含義如下:
- unsigned atrrib: 文件屬性的存儲(chǔ)位置。它存儲(chǔ)一個(gè)unsigned單元,用于表示文件的屬性。文件屬性是用位表示的,主要有以下一些:_A_ARCH(存檔)、 _A_HIDDEN(隱藏)、_A_NORMAL(正常)、_A_RDONLY(只讀)、_A_SUBDIR(文件夾)、_A_SYSTEM(系統(tǒng))。這些都是在中定義的宏,可以直接使用,而本身的意義其實(shí)是一個(gè)無(wú)符號(hào)整型(只不過(guò)這個(gè)整型應(yīng)該是2的幾次冪,從而保證只有一位為 1,而其他位為0)。既然是位表示,那么當(dāng)一個(gè)文件有多個(gè)屬性時(shí),它往往是通過(guò)位或的方式,來(lái)得到幾個(gè)屬性的綜合。例如只讀+隱藏+系統(tǒng)屬性,應(yīng)該為:_A_HIDDEN | _A_RDONLY | _A_SYSTEM 。
- time_t time_create: 文件創(chuàng)建時(shí)間。
- time_t time_access: 文件最后一次被訪問(wèn)的時(shí)間。
- time_t time_write: 文件最后一次被修改的時(shí)間。
- _fsize_t size: 文件的大小。
- char name [_MAX_FNAME ]:文件的文件名。這里的_MAX_FNAME是一個(gè)常量宏,它在頭文件中被定義,表示的是文件名的最大長(zhǎng)度。
查找文件需要用到_findfirst 和 _findnext 兩個(gè)函數(shù),這兩個(gè)函數(shù)包含在io.h庫(kù)中
1、_findfirst函數(shù):long _findfirst(const char *, struct _finddata_t *);
第一個(gè)參數(shù)為文件名,可以用"*.*"來(lái)查找所有文件,也可以用"*.cpp"來(lái)查找.cpp文件。第二個(gè)參數(shù)是_finddata_t結(jié)構(gòu)體指針。若查找成功,返回文件句柄,若失敗,返回-1。
2、_findnext函數(shù):int _findnext(long, struct _finddata_t *);
第一個(gè)參數(shù)為文件句柄,第二個(gè)參數(shù)同樣為_finddata_t結(jié)構(gòu)體指針。若查找成功,返回0,失敗返回-1。
3、_findclose()函數(shù):int _findclose(long);
只有一個(gè)參數(shù),文件句柄。若關(guān)閉成功返回0,失敗返回-1。
代碼及實(shí)現(xiàn)
需要輸出的文件
運(yùn)行結(jié)果
代碼
#include <iostream> #include <string> #include <fstream> #include <io.h> using namespace std void GetLineAndPrint(string in_name) { ifstream fin(in_name); if (!fin) { cerr << "open file error" << endl; exit(-1); } string str; while (getline(fin, str)) { cout << str << endl; } } int main() { struct _finddata_t fileinfo; string in_path; string in_name; cout << "輸入文件夾路徑:" ; cin >> in_path; string curr = in_path + "\\*.txt"; long handle; if ((handle = _findfirst(curr.c_str(), &fileinfo)) == -1L) { cout << "沒有找到匹配文件!" << endl; return 0; } else { in_name = in_path + "\\" + fileinfo.name; GetLineAndPrint(in_name); while (!(_findnext(handle, &fileinfo))) { in_name = in_path + "\\" + fileinfo.name; GetLineAndPrint(in_name); } _findclose(handle); } }
注:代碼在vs2017中編譯通過(guò)。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
參考資料:http://www.dbjr.com.cn/article/142285.htm
原文鏈接:https://www.cnblogs.com/bigyang/p/8547038.html
相關(guān)文章
C++中std::find函數(shù)介紹和使用場(chǎng)景
std::find函數(shù)是一個(gè)非常實(shí)用的通用查找算法,適用于各種場(chǎng)景,本文主要介紹了C++中std::find函數(shù)介紹和使用場(chǎng)景,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02C語(yǔ)言實(shí)現(xiàn)十六進(jìn)制與二進(jìn)制的相互轉(zhuǎn)換
這篇文章主要為大家詳細(xì)介紹了如何利用c語(yǔ)言實(shí)現(xiàn)將文件中十六進(jìn)制數(shù)據(jù)與二進(jìn)制數(shù)據(jù)相互轉(zhuǎn)換,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的可以學(xué)習(xí)一下2022-11-11從c++標(biāo)準(zhǔn)庫(kù)指針萃取器談一下traits技法(推薦)
本篇文章基于gcc中標(biāo)準(zhǔn)庫(kù)源碼剖析一下標(biāo)準(zhǔn)庫(kù)中的模板類pointer_traits,并且以此為例理解一下traits技法,對(duì)c++ traits技法源碼分析感興趣的朋友跟隨小編一起看看吧2021-07-07C語(yǔ)言每日練習(xí)之統(tǒng)計(jì)文本單詞數(shù)及高頻詞
本文文大家準(zhǔn)備了個(gè)C語(yǔ)言練習(xí)題:統(tǒng)計(jì)單詞數(shù)并找出頻率最高的單詞,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C語(yǔ)言有一定幫助,感興趣的可以了解一下2022-05-05深入探究協(xié)程在C++中的實(shí)現(xiàn)方式
協(xié)程可以被看作是計(jì)算機(jī)程序中的獨(dú)立功能塊,它們?cè)趫?zhí)行過(guò)程中能夠暫停和恢復(fù),與傳統(tǒng)的函數(shù)調(diào)用相比,協(xié)程更像是一種輕量級(jí)的線程,本文我們將深入探究協(xié)程在C++中的實(shí)現(xiàn)方式,文中有詳細(xì)的代碼示例供大家參考,需要的朋友可以參考下2023-12-12C++11之std::future對(duì)象的使用以及說(shuō)明
這篇文章主要介紹了C++11之std::future對(duì)象的使用以及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02C語(yǔ)言 選擇排序算法詳解及實(shí)現(xiàn)代碼
本文主要介紹C語(yǔ)言 選擇排序算法,這里對(duì)排序算法做了詳細(xì)說(shuō)明,并附代碼示例,有需要的小伙伴可以參考下2016-08-08