//如果涉及到大文件的遍历(大于4GB),可以将以下代码_finddata_t换成__finddata64_t,_findfirst换成_findfirst64,_findnext换成_findnext64

void dfsFolder(CString dirPath)
{
 _finddata_t FileInfo;
 CString tmp=dirPath;
 if (tmp.Right(1) != "\\")
  tmp += "\\";
 CString strfind = tmp + "*";
 long Handle = _findfirst(strfind, &FileInfo);
 if (Handle == -1L)
 {
  //cerr << "can not match the folder path" << endl;
  return ;
 }
 do{
  //判断是否有子目录
  if (FileInfo.attrib&_A_SUBDIR)
  {
   // 由于系统在进入一个子目录时,匹配到的头两个文件(夹)
   // 是"."(当前目录),".."(上一层目录)。需要忽略掉这两种情况
   if( (strcmp(FileInfo.name,".") != 0 ) &&(strcmp(FileInfo.name,"..") != 0))  
   {
    //判断是否处理隐藏文件夹、系统文件夹
    //if ((!(FileInfo.attrib&_A_HIDDEN)||PROC_HIDDEN)&&
    // (!(FileInfo.attrib&_A_SYSTEM)||PROC_SYSTEM))
    {
     CString newPath = dirPath + "\\" + FileInfo.name;
     //递归遍历更深层次的文件夹
     dfsFolder(newPath);
    }
   }
  }
  else 
  {

CString fileSizeStr;
    //文件大小
    if (FileInfo.size/1024.0<1)
    {
     fileSizeStr.Format("%I64dB",FileInfo.size);
    }
    else if (FileInfo.size/(1024.0*1024.0)<1)
    {
     fileSizeStr.Format("%.2I64fKB",FileInfo.size/1024.0);
    }

  //最后修改文件的时间
    CTime time(FileInfo.time_write);
    CString timeStr = time.Format( "%Y/%m/%d %H:%M:%S" );
   // 文件名字(包括后缀名)
   CString nameExt(FileInfo.name);
   int i=nameExt.ReverseFind('.');
   CString name=nameExt.Left(i);
   CString ext=nameExt.Mid(i+1);
  }
 }while (_findnext(Handle, &FileInfo) == 0);
 _findclose(Handle);
}

---------------------------------------------------------------------------------

//以下代码可以复制带有子文件夹的文件夹

void dfsCopyFolder(CString srcPath, CString dstPath)
{
 _finddata_t FileInfo;
 CString tmp=srcPath;
 if (tmp.Right(1) != "\\")
  tmp += "\\";
 CString strfind = tmp + "*";
 long Handle = _findfirst(strfind, &FileInfo);
 if (Handle == -1L)
 {
  //cerr << "can not match the folder path" << endl;
  return ;
 }
 do{
  //判断是否有子目录
  if (FileInfo.attrib&_A_SUBDIR)
  {
   // 由于系统在进入一个子目录时,匹配到的头两个文件(夹)
   // 是"."(当前目录),".."(上一层目录)。需要忽略掉这两种情况
   if( (strcmp(FileInfo.name,".") != 0 ) &&(strcmp(FileInfo.name,"..") != 0))  
   {
    //判断是否处理隐藏文件夹、系统文件夹
    //if ((!(FileInfo.attrib&_A_HIDDEN)||PROC_HIDDEN)&&
    // (!(FileInfo.attrib&_A_SYSTEM)||PROC_SYSTEM))
    {
     CString newSrcPath = srcPath + "\\" + FileInfo.name;
     CString newDstPath = dstPath + "\\" + FileInfo.name;
     if (!PathFileExists(newDstPath))//判断是否存在重名文件
     {
      //生成目标文件夹
      if(!CreateDirectory(newDstPath,NULL))  
      {
       //AfxMessageBox("创建文件夹失败!");
      }
     }
     //递归遍历更深层次的文件夹
     dfsCopyFolder(newSrcPath, newDstPath);
    }
   }
  }
  else 
  {
   // 文件名字(包括后缀名)
   CString nameExt(FileInfo.name);
   int i=nameExt.ReverseFind('.');
   CString name=nameExt.Left(i);
   CString ext=nameExt.Mid(i+1);
   CString srcFile=srcPath+"\\"+nameExt;
   CString dstFile=dstPath+"\\"+nameExt;
   BOOL b=CopyFile(srcFile, dstFile, false);//强行覆盖
   if (!b)
   {
    //AfxMessageBox("复制"+srcFile+"文件失败!");
   }

}
 }while (_findnext(Handle, &FileInfo) == 0);
 _findclose(Handle);
}

MFC dfs遍历文件的更多相关文章

  1. DFS遍历拷贝所有子文件夹及目录列表 (Java版)

    如题 注意,文件夹是不能拷贝的, 需要mkdir的 文件选择合适的流进行拷贝 main测试方法 /** * 主测试类,默认将D:\\base01 下的复制到D:\\base02 * @param ar ...

  2. MFC拖拽、选择目录、遍历文件

    1.选择目录 void CDecryptFileDlg::OnBnClickedSel() { std::wstring selectedDir; WCHAR szDir[MAX_PATH]; Zer ...

  3. 图之BFS和DFS遍历的实现并解决一次旅游中发现的问题

    这篇文章用来复习使用BFS(Breadth First Search)和DFS(Depth First Search) 并解决一个在旅游时遇到的问题. 关于图的邻接表存储与邻接矩阵的存储,各有优缺点. ...

  4. MFC 与Excel文件的交互操作

    假日快要结束了.带着沉重的心情写下之前关于MFC与Excel文件交互的总结. 因为VS的版本号不同可能在操作上有些差异.所以在此指明下本篇文章的project环境为VS2013,也建议大家用最新的. ...

  5. ORACEL上传BLOB,深度遍历文件夹

    // uploadingDlg.cpp : 实现文件// #include "stdafx.h"#include "uploading.h"#include & ...

  6. C#遍历文件夹下所有文件

    FolderForm.cs的代码如下: using System; using System.Collections.Generic; using System.Diagnostics; using ...

  7. windowsAPI遍历文件夹(速度高于递归)

    #region API 遍历文件夹及其子文件夹和子文件 #region 声明WIN32API函数以及结构 ************************************** [DllImpo ...

  8. C# 遍历文件夹下所有子文件夹中的文件,得到文件名

    假设a文件夹在F盘下,代码如下.将文件名输出到一个ListBox中using System.Data;using System.Drawing;using System.Linq;using Syst ...

  9. python 遍历文件夹 文件

    python 遍历文件夹 文件   import os import os.path rootdir = "d:\data" # 指明被遍历的文件夹 for parent,dirn ...

随机推荐

  1. Linux LSM(Linux Security Modules) Hook Technology

    目录 . 引言 . Linux Security Module Framework Introduction . LSM Sourcecode Analysis . LSMs Hook Engine: ...

  2. Aho-Corasick算法、多模正则匹配、Snort入门学习

    希望解决的问题 . 在一些高流量.高IO的WAF中,是如何对规则库(POST.GET)中的字符串进行多正则匹配的,是单条轮询执行,还是多模式并发执行 . Snort是怎么组织.匹配高达上千条的正则规则 ...

  3. java将一维数组拆分成二维数组

    package staticFactory; public class Array { public static void main(String[] args) { String[] a=new ...

  4. linux系统编程----统计一个目录下的普通文件个数

    主要是为了统计linux系统下一个指定目录下面的普通文件个数,运用目录操作的一些函数,配合递归调用来实现该功能. 首先介绍一下函数原型: 打开一个空目录                    DIR ...

  5. POJ3628 Bookshelf 2(01背包+dfs)

    Bookshelf 2 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8745   Accepted: 3974 Descr ...

  6. hashcode与字符串

    问题1. 不同的字符串可能会有相同的HashCode吗? hashcode是用来判断两个字符串是否相等的依据,不同的字符串不可能有相同的hashcode,但不同的hashCode经过与长度的取余,就很 ...

  7. MyBatis查询传一个参数时报错:There is no getter for property named 'sleevetype' in 'class java.lang.Integer

    用MyBatis进行查询,传入参数只有一个时(非Map)如int,报错 There is no getter for property named 'sleevetype' in 'class jav ...

  8. 使用.NET FrameWork获取CPU,内存使用率以及磁盘空间

    在以前,我们想获取CPU,内存等信息就不得不借助win32 API来实现.但现在,.NET FrameWork已经把这些API封装到.NET类库中了,所以我们可以借助.NET类库很轻松的获取这些信息. ...

  9. day4作业之信息表

    实在是太low了,终究是自己写的,记录下 #!/usr/bin/env python # coding=utf8 import os, re #这里我把查询这块分为3个函数了,纠结了很久是放一起还是分 ...

  10. SQL Server 2005 数据库复制(转载)

    对于一个地域分散的大型企业组织来说,构建具有典型的分布式计算机特征的大型企业管理信息系统时,总要解决一个很重要的问题:如何在多个不同数 据库服务器之间保证共享数据的一致性.之所以有这个重要的问题在于企 ...