MFC点点滴滴——打开文件夹并枚举所有文件(总结) .

 http://blog.csdn.net/zhd320/article/details/6767203

 

1.MFC中BROWSEINFO结构中包含有用户选中目录的重要信息。

BROWSEINFO结构  

●定义 

typedef struct_browseinfo  { 

 HWND hwndOwner; 

 LPCITEMIDLIST pidlRoot; 

 LPSTR pszDisplayName; 

 LPCSTR lpszTitle; 

 UINT ulFlags; 

 BFFCALLBACK lpfn; 

 LPARAM lParam; 

 int iImage;  }BROWSEINFO,*PBROWSEINFO,*LPBROWSEINFO;

●成员变量  

hwndOwner:浏览文件夹对话框的父窗体句柄。

  pidlRoot:ITEMIDLIST结构的地址,包含浏览时的初始根目录,而且只有被指定的目录和其子目录才显示在浏览文件夹对话框中。该成员变量可以是NULL,在此时桌面目录将被使用。

  pszDisplayName:用来保存用户选中的目录字符串的内存地址。该缓冲区的大小缺省是定义的MAX_PATH常量宏。

  lpszTitle:该浏览文件夹对话框对话框的显示文本,用来提示该浏览文件夹对话框的功能、作用和目的。

  ulFlags:该标志位描述了对话框的选项。它可以为0,也可以是以下常量的任意组合:

  BIF_BROWSEFORCOMPUTER:返回计算机名。除非用户选中浏览器中的一个计算机名,否则该对话框中的“OK”按钮为灰色。

  BIF_BROWSEFORPRINTER:返回打印机名。除非选中一个打印机名,否则“OK”按钮为灰色。

  BIF_BROWSEINCLUDEFILES:浏览器将显示目录,同时也显示文件。

  BIF_DONTGOBELOWDOMAIN:在树形视窗中,不包含域名底下的网络目录结构。

  BIF_EDITBOX:浏览对话框中包含一个编辑框,在该编辑框中用户可以输入选中项的名字。

  BIF_RETURNFSANCESTORS:返回文件系统的一个节点。仅仅当选中的是有意义的节点时,“OK”按钮才可以使用。

  BIF_RETURNONLYFSDIRS:仅仅返回文件系统的目录。例如:在浏览文件夹对话框中,当选中任意一个目录时,该“OK”按钮可用,而当选中“我的电脑”或“网上邻居”等非有意义的节点时,“OK”按钮为灰色。

  BIF_STATUSTEXT:在对话框中包含一个状态区域。通过给对话框发送消息使回调函数设置状态文本。

  BIF_VALIDATE:当没有BIF_EDITBOX标志位时,该标志位被忽略。如果用户在编辑框中输入的名字非法,浏览对话框将发送BFFM_VALIDATEFAILED消息给回调函数。

  lpfn:应用程序定义的浏览对话框回调函数的地址。当对话框中的事件发生时,该对话框将调用回调函数。该参数可用为NULL。

  lParam:对话框传递给回调函数的一个参数指针。

  iImage:与选中目录相关的图像。该图像将被指定为系统图像列表中的索引值。

2.ITEMIDLIST        

 Windows Shell的一个功能在于管理并提供方法存取系统中的众多对像,這些对像包括了文件,网路上的计算机,控制面板程序,回收站等等,为了识别每一个对像,Windows Shell使用了Item ID来表示它們,而Iten ID Lists用来表示一个对像的路径。所以,ITEMID和ITEMIDLIST的关系类似于文件名和路径的关系。如果只对文件系统而言的话,ITEMIDLIST可以看成是路径的另一中表示法,Windows Shell也提供了函数來进行转化。         

   如果SHBrowseForFolder函数返回的ITEMIDLIST结构指针不为NULL,就可以使用SHGetPathFromIDList函数取得存储于ITEMIDLIST结构指针中的路径信息。SHGetPathFromIDList函数的原型如下:

WINSHELLAPI BOOL WINAPI SHGetPathFromIDList( LPCITEMIDLIST pidl, LPSTR pszPath ); 

第一个参数就是存储了路径信息的ITEMIDLIST结构指针,第二个参数是一个字符缓冲区,用于接收字符串。它应当有_MAX_PATH所指定的长度,_MAX_PATH在Windows系统中被定义为260个字符,其大小可以是260或520个字节,这取决于是否使用了Unicode。

3.CFileFind

CObject

└CFileFind

MFC类CFileFind执行本地文件查找,是CGopherFileFind和CFtpFileFind的基类;后两类用于Internet文件查找。CFileFind包括的成员函数有开始查找、定位文件、返回标题名或路径。对于Internet查找来说,GetFileURL返回文件的URL。CFileFind是为另两类查找特殊服务器设计的MFC类的基类,CGopherFileFind在Gopher服务器上工作,CFtpFileFind在FTP服务器上工作,这些类为用户查找文件提供了一种无缝机制,与服务器协议、文件类型、地点、本地机器或远程服务器无关。

以下代码将当前目录下的文件枚举出来并打印每个文件名:

view plain copy to clipboard print ?
  1. CFileFind finder;  
  2. BOOL bWorking = finder.FindFile("*.*");  
  3. while(bWorking)  
  4. {  
  5.     bWorking=finder.FindNextFile();  
  6.     m_str+=finder.GetFileName();  
  7. }  
  8. UpdateData(FALSE);     

CFileFind finder; BOOL bWorking = finder.FindFile("*.*"); while(bWorking) { bWorking=finder.FindNextFile(); m_str+=finder.GetFileName(); } UpdateData(FALSE);

CFtpFileFind, CGopherFileFind, CInternetFile, CGopherFile, CHttpFileCFileFind类的成员构造函数 CFileFind构造一个CFileFind对象。

属性 GetLength获取找到文件的长度,以字节为单位

GetFileName获取找到文件的名字

GetFilePath找到文件的全路径

GetFileTitle获取找到文件的标题,标题不包括扩展内容

GetFileURL获取找到文件的URL,包括文件路径

GetRoot获取找到文件根目录

GetCreationTime获取文件创建时间

GetLastAccessTime获取文件最后一次打开的时间

GetLastWriteTime文件最后改变和存储的时间

MatchesMask指定要找的文件的属性

IsDots查看文件名是否是包含"."或"..",以表明它的确是一个目录

IsReadOnly文件是否是只读IsDirectory文件是否是目录

IsCompressed文件是否是压缩

IsSystem文件是否是系统文件

IsHidden文件是否是隐藏

IsTemporary文件是否是临时的

IsNormal文件是否是常规的(无其它属性)

IsArchived文件是否是档案 

CFileFind用法

1、CFileFind类的声明文件保存在afx.h头文件中。
2、该类的实现的功能:执行本地文件的查找(查找某个具体的文件,查找某类文件x*.x*,查找所有文件*.*)
3、CFileFind类是CGopherFileFind和CFtpFileFind类的基类。
4、CFileFind类的构造函数::CFileFind()和关闭函数::Close()我会成对使用。
5、CFileFind类的成员函数我根据其操作特性划分为3类:查找操作类、获得文件属性类、判断文件属性类。(下面我先进行函数罗列并没有完整的描述函数的参数)
查找操作类
::FindFile();
::FindNextFile();
获得文件属性类
::GetCreationTime();
::GetLastAccessTime();
::GetLastWriteTime();
::GetFileName(); //带后缀的文件名
::GetRoot();  //盘符  
::GetFilePath(); //全路径
::GetFileTitle(); //不带后缀的文件名
::GetFileURL(); //URL串
::GetLength(); //

判断文件属性类
::IsArchived();
::IsCompressed();
::IsDirectory();
::IsDots();//很重要哦,判断是否是次层目录或父目录
::IsHidden();
::IsNormal();
::IsReadOnly();
::IsSystem();
::IsTemporary();
::MatchesMask();
6、CFileFind类中成员函数使用应注意的顺序
在创建了CFileFind对象后,先执行::FindFile()函数,然后执行::FindNextFile(),然后选择执行(获得文件属性类)的函数或者(判断文件属性类)函数。
7、CFileFind类成员函数的详细分析
virtual BOOL FindFile(LPCTSTR pstrName = null,DWORD dwUnused = 0);
该函数若返回非0 则表明执行成功,0 则表明执行不成功。
pstrName:需要查找的文件名,例:“E:\\编程工具
\\VC++\\MFC例子.rar”,“E:\\编程工具\\VC++\\MFC*.rar”,“E:\\编程工具\\VC++\\*.*”,也可以是NULL表示“*.*”。
dwUnused:必须为0


 

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////隔隔更快乐

void CDialog::OnButtonBrowser()

{   // TODO: Add your control notification handler code here

UpdateData(TRUE);    //首先是将编辑框中字符串赋值给编辑框的一个关联变量

char szDir[MAX_PATH]; //

BROWSEINFO bi;

ITEMIDLIST *pidl;

bi.hwndOwner = this->m_hWnd; //弹出对话框的句柄

bi.pidlRoot = NULL;                    //浏览时的初始根目录,NULL为桌面目录

bi.pszDisplayName = szDir;       //用来暂存所选中的目录地址

bi.lpszTitle = "请选择目录";        //提示对话框的功能

bi.ulFlags = BIF_STATUSTEXT | BIF_RETURNONLYFSDIRS;//仅返回文件系统目录

bi.lpfn = NULL;   //回调函数地址,可以为NULL

bi.lParam = 0;    //回调函数的一个参数指针,可以为0

bi.iImage = 0;   //与选中目录相关的图像

pidl = SHBrowseForFolder(&bi);//调用显示选择对话框

if(pidl == NULL) return;

if(!SHGetPathFromIDList(pidl, szDir)) //取得文件夹路径放到szDir中  

 return ;

else    

m_strPathName = szDir;    //在编辑框中显示选中的目录

UpdateData(FALSE);     //刷新编辑框}

//枚举目录中的文件

view plain copy to clipboard print ?
  1. void   ListFolder(CString   sPath)   
  2. {   
  3. CFileFind   ff;   
  4. BOOL   bFound;   
  5. bFound   =   ff.FindFile(sPath   +   "\\*.* ");   
  6. while(bFound)   
  7. {   
  8. bFound   =   ff.FindNextFile();   
  9. CString   sFilePath   =   ff.GetFilePath();   
  10.   
  11. if(ff.IsDirectory())   
  12. {   
  13. if(!ff.IsDots()) //不是本级目录或父目录(.和..)   
  14. ListFolder(sFilePath);   
  15. }   
  16. else   
  17. {   
  18. AfxMessageBox(sFilePath);   
  19. }   
  20. }   
  21. ff.Close();   
  22. }  

 

你可能感兴趣的:(VC++)