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

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

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

前言

前段時間做項目需要讀取一個文件夾里面所有的txt文件,查詢資料后得到以下實現(xiàn)方法:

首先了解一下這個結構體

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: 文件屬性的存儲位置。它存儲一個unsigned單元,用于表示文件的屬性。文件屬性是用位表示的,主要有以下一些:_A_ARCH(存檔)、 _A_HIDDEN(隱藏)、_A_NORMAL(正常)、_A_RDONLY(只讀)、_A_SUBDIR(文件夾)、_A_SYSTEM(系統(tǒng))。這些都是在中定義的宏,可以直接使用,而本身的意義其實是一個無符號整型(只不過這個整型應該是2的幾次冪,從而保證只有一位為 1,而其他位為0)。既然是位表示,那么當一個文件有多個屬性時,它往往是通過位或的方式,來得到幾個屬性的綜合。例如只讀+隱藏+系統(tǒng)屬性,應該為:_A_HIDDEN | _A_RDONLY | _A_SYSTEM 。
  • time_t time_create: 文件創(chuàng)建時間。
  • time_t time_access: 文件最后一次被訪問的時間。
  • time_t time_write: 文件最后一次被修改的時間。
  • _fsize_t size: 文件的大小。
  • char name [_MAX_FNAME ]:文件的文件名。這里的_MAX_FNAME是一個常量宏,它在頭文件中被定義,表示的是文件名的最大長度。

查找文件需要用到_findfirst 和 _findnext 兩個函數(shù),這兩個函數(shù)包含在io.h庫中

1、_findfirst函數(shù):long _findfirst(const char *, struct _finddata_t *);

第一個參數(shù)為文件名,可以用"*.*"來查找所有文件,也可以用"*.cpp"來查找.cpp文件。第二個參數(shù)是_finddata_t結構體指針。若查找成功,返回文件句柄,若失敗,返回-1。

2、_findnext函數(shù):int _findnext(long, struct _finddata_t *);

第一個參數(shù)為文件句柄,第二個參數(shù)同樣為_finddata_t結構體指針。若查找成功,返回0,失敗返回-1。

3、_findclose()函數(shù):int _findclose(long);

只有一個參數(shù),文件句柄。若關閉成功返回0,失敗返回-1。

代碼及實現(xiàn)

需要輸出的文件

運行結果

代碼

#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中編譯通過。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

參考資料:http://www.dbjr.com.cn/article/142285.htm

原文鏈接:https://www.cnblogs.com/bigyang/p/8547038.html

相關文章

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

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

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

    C語言實現(xiàn)十六進制與二進制的相互轉換

    這篇文章主要為大家詳細介紹了如何利用c語言實現(xiàn)將文件中十六進制數(shù)據(jù)與二進制數(shù)據(jù)相互轉換,文中的示例代碼講解詳細,具有一定的借鑒價值,感興趣的可以學習一下
    2022-11-11
  • 從c++標準庫指針萃取器談一下traits技法(推薦)

    從c++標準庫指針萃取器談一下traits技法(推薦)

    本篇文章基于gcc中標準庫源碼剖析一下標準庫中的模板類pointer_traits,并且以此為例理解一下traits技法,對c++ traits技法源碼分析感興趣的朋友跟隨小編一起看看吧
    2021-07-07
  • C++實現(xiàn)添加桌面右鍵新建菜單

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

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

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

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

    C語言每日練習之統(tǒng)計文本單詞數(shù)及高頻詞

    本文文大家準備了個C語言練習題:統(tǒng)計單詞數(shù)并找出頻率最高的單詞,文中的示例代碼講解詳細,對我們學習C語言有一定幫助,感興趣的可以了解一下
    2022-05-05
  • 深入探究協(xié)程在C++中的實現(xiàn)方式

    深入探究協(xié)程在C++中的實現(xiàn)方式

    協(xié)程可以被看作是計算機程序中的獨立功能塊,它們在執(zhí)行過程中能夠暫停和恢復,與傳統(tǒng)的函數(shù)調用相比,協(xié)程更像是一種輕量級的線程,本文我們將深入探究協(xié)程在C++中的實現(xiàn)方式,文中有詳細的代碼示例供大家參考,需要的朋友可以參考下
    2023-12-12
  • C++中不能被重載的運算符介紹

    C++中不能被重載的運算符介紹

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

    C++11之std::future對象的使用以及說明

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

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

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

最新評論