詳解C/C++如何獲取路徑下所有文件及其子目錄的文件名
一、功能描述
需要提取某個(gè)文件夾下所有文件名字,當(dāng)包含子目錄時(shí),將子目錄及其路徑獲取到。
二、實(shí)現(xiàn)方式
使用C語(yǔ)言的opendir函數(shù)
DIR* dp; struct dirent* dirp; if ((dp = opendir(sdir.c_str())) != NULL) { dirp = readdir(dp) }
通過(guò)readir讀取到的dirp中包含的d_type具有如下類型及其含義:
enum { DT_UNKNOWN = 0, # define DT_UNKNOWN DT_UNKNOWN DT_FIFO = 1, # define DT_FIFO DT_FIFO DT_CHR = 2, # define DT_CHR DT_CHR DT_DIR = 4, # define DT_DIR DT_DIR DT_BLK = 6, # define DT_BLK DT_BLK DT_REG = 8, # define DT_REG DT_REG DT_LNK = 10, # define DT_LNK DT_LNK DT_SOCK = 12, # define DT_SOCK DT_SOCK DT_WHT = 14 # define DT_WHT DT_WHT };
參考官方文檔可知
DT_UNKNOWN ¶
The type is unknown. Only some filesystems have full support to return the type of the file, others might always return this value.
未知類型
DT_REG
A regular file. 常規(guī)文件
DT_DIR
A directory. 目錄
DT_FIFO
A named pipe, or FIFO. See FIFO Special Files.
DT_SOCK
A local-domain socket. 套接字文件
DT_CHR
A character device. 字符設(shè)備
DT_BLK
A block device. 塊設(shè)備,比如掛載的硬盤之類
DT_LNK
A symbolic link. 鏈接文件
三、代碼實(shí)現(xiàn)
通過(guò)遞歸的方式,獲取該目錄及其子目錄下的所有文件及其路徑名
#include <dirent.h> #include <vector> /** * @brief GetFiles: 獲取文件夾內(nèi)的所有文件名字 * @param sdir * @param bsubdir: true 包含子目錄下的文件 * @return */ std::vector<std::string> GetFiles(const std::string& sdir = ".", bool bsubdir = true) { DIR* dp; struct dirent* dirp; std::vector<std::string> filenames; if ((dp = opendir(sdir.c_str())) != NULL) { while ((dirp = readdir(dp)) != NULL) { if (strcmp(".", dirp->d_name) == 0 || strcmp("..", dirp->d_name) == 0) continue; if (dirp->d_type != DT_DIR) filenames.push_back(sdir + "/" + dirp->d_name); if (bsubdir && dirp->d_type == DT_DIR) { std::vector<std::string> names = GetFiles(sdir + "/" + dirp->d_name); filenames.insert(filenames.begin(), names.begin(), names.end()); } } } closedir(dp); return filenames; }
到此這篇關(guān)于詳解C/C++如何獲取路徑下所有文件及其子目錄的文件名的文章就介紹到這了,更多相關(guān)C++獲取路徑下文件文件名內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解讀堆排序算法及用C++實(shí)現(xiàn)基于最大堆的堆排序示例
把待排序的數(shù)組構(gòu)造出最大堆是進(jìn)行堆排序操作的基本方法,這里將帶大家來(lái)解讀堆排序算法及用C++實(shí)現(xiàn)基于最大堆的堆排序示例,首先從堆排序的概念開始:2016-06-06C語(yǔ)言中強(qiáng)制地址跳轉(zhuǎn)詳解
這篇文章主要介紹了C語(yǔ)言中強(qiáng)制地址跳轉(zhuǎn)詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05Qt實(shí)現(xiàn)指針式時(shí)鐘 Qt實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘
這篇文章主要為大家詳細(xì)介紹了Qt實(shí)現(xiàn)指針式時(shí)鐘,Qt實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘,兩者相互切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07CString,字符串,整數(shù)等相互轉(zhuǎn)換方法(推薦)
下面小編就為大家?guī)?lái)一篇CString,字符串,整數(shù)等相互轉(zhuǎn)換方法(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09StretchBlt函數(shù)和BitBlt函數(shù)用法案例詳解
這篇文章主要介紹了StretchBlt函數(shù)和BitBlt函數(shù)用法案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08C++實(shí)現(xiàn)簡(jiǎn)單24點(diǎn)游戲
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)單24點(diǎn)游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03