zoukankan      html  css  js  c++  java
  • VC/MFC 下 递归遍历目录下的所有子目录及文件

    在MFC下要实现文件夹的递归遍历,可用CFileFind类,依次读取文件夹下的子文件夹和文件,并判断通过判断是文件夹还是文件来决定递归遍历。递归遍历代码如下:

    /************************************************************************/
    /* 遍历打包目录下的所有文件                                             */
    /************************************************************************/
    void CCopyFileCheckerDlg::FindFileInDir(CString rootDir)
    {
    	// 查找当前路径下的所有文件夹和文件
    	CString strDir = rootDir;
    	strDir += "\*.*";
    
    	// 遍历得到所有子文件夹名
    	CFileFind finder; 
    	BOOL bWorking = finder.FindFile(strDir);
    	
    	while (bWorking)  
    	{  
    		bWorking = finder.FindNextFile();
    		if (finder.IsDirectory() && "." != finder.GetFileName() && ".." != finder.GetFileName())//注意该句需要排除“.”“..”
    		{
    			//递归调用
    			if(finder.GetFileName() != L"源PE文件")
    				FindFileInDir(finder.GetFilePath());
    		}
    		else
    		{
    			
    			CString strFile = finder.GetFilePath();
    			CString strFileName = finder.GetFileName();
    			CString strFileExtension = GetFileExtension(strFileName);
    			if(L"." != strFileName&&L".." != strFileName)
    			{
    				
    				if(strFileExtension.CompareNoCase(L"exe") == 0 ||strFileExtension.CompareNoCase(L"dll")==0)
    				{
    					if(IsNeedCopy(strFileName,strFile))
    					{
    						m_nPEFileNum ++;
    						INT nRow = m_listResult.InsertItem(m_nCount, strFile);//插入行
    						m_listResult.SetItemText(nRow, 1, strFile);//设置数据
    						m_listResult.SetCheck(nRow,TRUE);
    						m_progress.SetPos(m_nCount);
    
    					}
    				}
    			}
    			
    		}
    	} 
    	finder.Close();
    }
    

      

  • 相关阅读:
    Zookeeper 选举机制
    Hadoop Yarn任务调度器
    Hadoop Yarn工作机制 Job提交流程
    Hadoop 切片机制
    Hadoop MapReduce工作流程
    Hadoop HDFS读写数据流程
    数据仓库 拉链表
    高动态范围照片*5
    Java实现的窗口计算器
    拍摄制作星轨拖尾视频 之 前期拍摄
  • 原文地址:https://www.cnblogs.com/JczmDeveloper/p/3571438.html
Copyright © 2011-2022 走看看