• c++遍历指定文件夹下的所有的文件


    linux:

    #include <sys/types.h>
    #include <dirent.h>
    #include <stdio.h>
    #include <errno.h>
    int main(int argc,char *argv[])
    {

    DIR *dp;
    struct dirent *dirp;
    int n=0;
    if (argc!=2)
    {
    printf("a single argument is required\n");
    return 0;
    }
    if((dp=opendir(argv[1]))==NULL)
    printf("can't open %s",argv[1]);
    while (((dirp=readdir(dp))!=NULL) && (n<=50))
    {
    n++;
    printf("%s\n",dirp->d_name);
    }
    printf("\n");
    closedir(dp);

    return 0;
    }

    某牛人封装好的类

    // bb.cpp : Defines the entry point for the console application.
    //

    #include "stdafx.h"


    #include "stdlib.h"
    #include "direct.h"
    #include "string.h"
    #include "io.h"
    #include "stdio.h"
    #include <iostream>
    using namespace std;
    class CBrowseDir
    {
    protected:
    //存放初始目录的绝对路径,以'\'结尾
    char m_szInitDir[_MAX_PATH];

    public:
    //缺省构造器
    CBrowseDir();

    //设置初始目录为dir,如果返回false,表示目录不可用
    bool SetInitDir(const char *dir);

    //开始遍历初始目录及其子目录下由filespec指定类型的文件
    //filespec可以使用通配符 * ?,不能包含路径。
    //如果返回false,表示遍历过程被用户中止
    bool BeginBrowse(const char *filespec);

    protected:
    //遍历目录dir下由filespec指定的文件
    //对于子目录,采用迭代的方法
    //如果返回false,表示中止遍历文件
    bool BrowseDir(const char *dir,const char *filespec);

    //函数BrowseDir每找到一个文件,就调用ProcessFile
    //并把文件名作为参数传递过去
    //如果返回false,表示中止遍历文件
    //用户可以覆写该函数,加入自己的处理代码
    virtual bool ProcessFile(const char *filename);

    //函数BrowseDir每进入一个目录,就调用ProcessDir
    //并把正在处理的目录名及上一级目录名作为参数传递过去
    //如果正在处理的是初始目录,则parentdir=NULL
    //用户可以覆写该函数,加入自己的处理代码
    //比如用户可以在这里统计子目录的个数
    virtual void ProcessDir(const char *currentdir,const char *parentdir);
    };

    CBrowseDir::CBrowseDir()
    {
    //用当前目录初始化m_szInitDir
    getcwd(m_szInitDir,_MAX_PATH);
    //如果目录的最后一个字母不是'\',则在最后加上一个'\'
    int len=strlen(m_szInitDir);
    if (m_szInitDir[len-1] != '\\')
    strcat(m_szInitDir,"\\");
    }

    bool CBrowseDir::SetInitDir(const char *dir)
    {
    //先把dir转换为绝对路径
    if (_fullpath(m_szInitDir,dir,_MAX_PATH) == NULL)
    return false;
    //判断目录是否存在
    if (_chdir(m_szInitDir) != 0)
    return false;
    //如果目录的最后一个字母不是'\',则在最后加上一个'\'
    int len=strlen(m_szInitDir);
    if (m_szInitDir[len-1] != '\\')
    strcat(m_szInitDir,"\\");
    return true;
    }

    bool CBrowseDir::BeginBrowse(const char *filespec)
    {
    ProcessDir(m_szInitDir,NULL);
    return BrowseDir(m_szInitDir,filespec);
    }

    bool CBrowseDir::BrowseDir(const char *dir,const char *filespec)
    {
    _chdir(dir);

    //首先查找dir中符合要求的文件
    long hFile;
    _finddata_t fileinfo;
    if ((hFile=_findfirst(filespec,&fileinfo)) != -1)
    {
    do
    {
    //检查是不是目录
    //如果不是,则进行处理
    if (!(fileinfo.attrib & _A_SUBDIR))
    {
    char filename[_MAX_PATH];
    strcpy(filename,dir);
    strcat(filename,fileinfo.name);
    cout << filename << endl;
    if (!ProcessFile(filename))
    return false;
    }
    } while (_findnext(hFile,&fileinfo) == 0);
    _findclose(hFile);
    }
    //查找dir中的子目录
    //因为在处理dir中的文件时,派生类的ProcessFile有可能改变了
    //当前目录,因此还要重新设置当前目录为dir。
    //执行过_findfirst后,可能系统记录下了相关信息,因此改变目录
    //对_findnext没有影响。
    _chdir(dir);
    if ((hFile=_findfirst("*.*",&fileinfo)) != -1)
    {
    do
    {
    //检查是不是目录
    //如果是,再检查是不是 . 或 ..
    //如果不是,进行迭代
    if ((fileinfo.attrib & _A_SUBDIR))
    {
    if (strcmp(fileinfo.name,".") != 0 && strcmp
    (fileinfo.name,"..") != 0)
    {
    char subdir[_MAX_PATH];
    strcpy(subdir,dir);
    strcat(subdir,fileinfo.name);
    strcat(subdir,"\\");
    ProcessDir(subdir,dir);
    if (!BrowseDir(subdir,filespec))
    return false;
    }
    }
    } while (_findnext(hFile,&fileinfo) == 0);
    _findclose(hFile);
    }
    return true;
    }

    bool CBrowseDir::ProcessFile(const char *filename)
    {
    return true;
    }

    void CBrowseDir::ProcessDir(const char
    *currentdir,const char *parentdir)
    {
    }

    //从CBrowseDir派生出的子类,用来统计目录中的文件及子目录个数
    class CStatDir:public CBrowseDir
    {
    protected:
    int m_nFileCount; //保存文件个数
    int m_nSubdirCount; //保存子目录个数
    public:
    //缺省构造器
    CStatDir()
    {
    //初始化数据成员m_nFileCount和m_nSubdirCount
    m_nFileCount=m_nSubdirCount=0;
    }

    //返回文件个数
    int GetFileCount()
    {
    return m_nFileCount;
    }

    //返回子目录个数
    int GetSubdirCount()
    {
    //因为进入初始目录时,也会调用函数ProcessDir,
    //所以减1后才是真正的子目录个数。
    return m_nSubdirCount-1;
    }

    protected:
    //覆写虚函数ProcessFile,每调用一次,文件个数加1
    virtual bool ProcessFile(const char *filename)
    {
    m_nFileCount++;
    return CBrowseDir::ProcessFile(filename);
    }

    //覆写虚函数ProcessDir,每调用一次,子目录个数加1
    virtual void ProcessDir
    (const char *currentdir,const char *parentdir)
    {
    m_nSubdirCount++;
    CBrowseDir::ProcessDir(currentdir,parentdir);
    }
    };

    void main()
    {
    //获取目录名
    char buf[256];
    printf("请输入要统计的目录名:");
    gets(buf);

    freopen("output.txt","w",stdout);

    //构造类对象
    CStatDir statdir;

    //设置要遍历的目录
    if (!statdir.SetInitDir(buf))
    {
    puts("目录不存在。");
    return;
    }

    //开始遍历
    statdir.BeginBrowse("*.*");
    // printf("文件总数: %d\n子目录总数:%d\n",statdir.GetFileCount(),statdir.GetSubdirCount());
    }

    }

    转载来自:http://blog.sina.com.cn/s/blog_62466e480100qqi6.html


    ps:我的新博客地址:http://www.xinghaixu.com


  • 相关阅读:
    2016/3/16 高级查询 ①连接查询 ②联合查询 ③子查询 无关 相关
    2016/3/13 七种查询 (普通查询 条件查询 排序查询 模糊查询 统计查询 分组查询 分页查询 )
    2016/3/13 MySQL 增删查改 CRUD 用代码实现
    2016/3/10 数据库简单操作( 创建数据库 创建表 数值类型 主键 外键 自动递增 )
    2016/3/10 PHP环境搭建 LAMP WAMP
    2016/3/10 PHP (超文本预处理器) 是什么?
    2016/3/1 淘宝 腾讯 网易 css初始化代码 以及最基础的初始化
    判断i在字符串中出现的次数(2016.1.12P141-1)
    2016-1-9作业——输出二维数组的和
    2016-1-8作业
  • 原文地址:https://www.cnblogs.com/xcxinghai/p/3283887.html
Copyright © 2020-2023  润新知