MFC dfs遍历文件
//如果涉及到大文件的遍历(大于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遍历文件的更多相关文章
- DFS遍历拷贝所有子文件夹及目录列表 (Java版)
如题 注意,文件夹是不能拷贝的, 需要mkdir的 文件选择合适的流进行拷贝 main测试方法 /** * 主测试类,默认将D:\\base01 下的复制到D:\\base02 * @param ar ...
- MFC拖拽、选择目录、遍历文件
1.选择目录 void CDecryptFileDlg::OnBnClickedSel() { std::wstring selectedDir; WCHAR szDir[MAX_PATH]; Zer ...
- 图之BFS和DFS遍历的实现并解决一次旅游中发现的问题
这篇文章用来复习使用BFS(Breadth First Search)和DFS(Depth First Search) 并解决一个在旅游时遇到的问题. 关于图的邻接表存储与邻接矩阵的存储,各有优缺点. ...
- MFC 与Excel文件的交互操作
假日快要结束了.带着沉重的心情写下之前关于MFC与Excel文件交互的总结. 因为VS的版本号不同可能在操作上有些差异.所以在此指明下本篇文章的project环境为VS2013,也建议大家用最新的. ...
- ORACEL上传BLOB,深度遍历文件夹
// uploadingDlg.cpp : 实现文件// #include "stdafx.h"#include "uploading.h"#include & ...
- C#遍历文件夹下所有文件
FolderForm.cs的代码如下: using System; using System.Collections.Generic; using System.Diagnostics; using ...
- windowsAPI遍历文件夹(速度高于递归)
#region API 遍历文件夹及其子文件夹和子文件 #region 声明WIN32API函数以及结构 ************************************** [DllImpo ...
- C# 遍历文件夹下所有子文件夹中的文件,得到文件名
假设a文件夹在F盘下,代码如下.将文件名输出到一个ListBox中using System.Data;using System.Drawing;using System.Linq;using Syst ...
- python 遍历文件夹 文件
python 遍历文件夹 文件 import os import os.path rootdir = "d:\data" # 指明被遍历的文件夹 for parent,dirn ...
随机推荐
- Linux LSM(Linux Security Modules) Hook Technology
目录 . 引言 . Linux Security Module Framework Introduction . LSM Sourcecode Analysis . LSMs Hook Engine: ...
- Aho-Corasick算法、多模正则匹配、Snort入门学习
希望解决的问题 . 在一些高流量.高IO的WAF中,是如何对规则库(POST.GET)中的字符串进行多正则匹配的,是单条轮询执行,还是多模式并发执行 . Snort是怎么组织.匹配高达上千条的正则规则 ...
- java将一维数组拆分成二维数组
package staticFactory; public class Array { public static void main(String[] args) { String[] a=new ...
- linux系统编程----统计一个目录下的普通文件个数
主要是为了统计linux系统下一个指定目录下面的普通文件个数,运用目录操作的一些函数,配合递归调用来实现该功能. 首先介绍一下函数原型: 打开一个空目录 DIR ...
- POJ3628 Bookshelf 2(01背包+dfs)
Bookshelf 2 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8745 Accepted: 3974 Descr ...
- hashcode与字符串
问题1. 不同的字符串可能会有相同的HashCode吗? hashcode是用来判断两个字符串是否相等的依据,不同的字符串不可能有相同的hashcode,但不同的hashCode经过与长度的取余,就很 ...
- 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 ...
- 使用.NET FrameWork获取CPU,内存使用率以及磁盘空间
在以前,我们想获取CPU,内存等信息就不得不借助win32 API来实现.但现在,.NET FrameWork已经把这些API封装到.NET类库中了,所以我们可以借助.NET类库很轻松的获取这些信息. ...
- day4作业之信息表
实在是太low了,终究是自己写的,记录下 #!/usr/bin/env python # coding=utf8 import os, re #这里我把查询这块分为3个函数了,纠结了很久是放一起还是分 ...
- SQL Server 2005 数据库复制(转载)
对于一个地域分散的大型企业组织来说,构建具有典型的分布式计算机特征的大型企业管理信息系统时,总要解决一个很重要的问题:如何在多个不同数 据库服务器之间保证共享数据的一致性.之所以有这个重要的问题在于企 ...