欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++從一個(gè)文件夾中讀出所有txt文件的方法示例

 更新時(shí)間:2018年03月13日 10:50:07   作者:Hahallo  
這篇文章主要給大家介紹了關(guān)于C++從一個(gè)文件夾中讀出所有txt文件的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。

前言

前段時(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)景

    C++中std::find函數(shù)介紹和使用場(chǎng)景

    std::find函數(shù)是一個(gè)非常實(shí)用的通用查找算法,適用于各種場(chǎng)景,本文主要介紹了C++中std::find函數(shù)介紹和使用場(chǎng)景,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02
  • C語(yǔ)言實(shí)現(xiàn)十六進(jìn)制與二進(jìn)制的相互轉(zhuǎn)換

    C語(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技法(推薦)

    從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-07
  • C++實(shí)現(xiàn)添加桌面右鍵新建菜單

    C++實(shí)現(xiàn)添加桌面右鍵新建菜單

    本文給大家匯總了3個(gè)版本的C++實(shí)現(xiàn)添加桌面右鍵新建菜單的代碼,陸陸續(xù)續(xù)寫的,有需要的小伙伴可以根據(jù)自己的需求來(lái)選擇
    2016-01-01
  • 總結(jié)一次C++ 程序優(yōu)化歷程

    總結(jié)一次C++ 程序優(yōu)化歷程

    這篇文章主要記錄了一次C++程序優(yōu)化的歷程,給大家優(yōu)化C++程序一些啟發(fā),感興趣的朋友可以了解下
    2020-09-09
  • C語(yǔ)言每日練習(xí)之統(tǒng)計(jì)文本單詞數(shù)及高頻詞

    C語(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é)程在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-12
  • C++中不能被重載的運(yùn)算符介紹

    C++中不能被重載的運(yùn)算符介紹

    其實(shí)在C/C++ 里大多數(shù)運(yùn)算符都可以在C++中被重載的。C 的運(yùn)算符中只有 . 和 ?:(以及 sizeof,技術(shù)上可以看作一個(gè)運(yùn)算符)不可以被重載
    2013-10-10
  • C++11之std::future對(duì)象的使用以及說(shuō)明

    C++11之std::future對(duì)象的使用以及說(shuō)明

    這篇文章主要介紹了C++11之std::future對(duì)象的使用以及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • C語(yǔ)言 選擇排序算法詳解及實(shí)現(xiàn)代碼

    C語(yǔ)言 選擇排序算法詳解及實(shí)現(xiàn)代碼

    本文主要介紹C語(yǔ)言 選擇排序算法,這里對(duì)排序算法做了詳細(xì)說(shuō)明,并附代碼示例,有需要的小伙伴可以參考下
    2016-08-08

最新評(píng)論