我是思路是先展开所有的分支,然后从根开始
GetNextItem(hti,TVGN_NEXTVISIBLE),寻找符合条件的分支。
可能我对遍历树存在误解,请教大家,谢谢HTREEITEM hti =pTreeCtrl->GetRootItem();
HTREEITEM hItem;
do
{
ExpandBranch(pTreeCtrl,hti);
}
while((hti = pTreeCtrl->GetNextSiblingItem( hti )) != NULL );hti =pTreeCtrl->GetRootItem();
while(hti)
{
hItem=pTreeCtrl->GetNextItem(hti,TVGN_NEXTVISIBLE);
if( (hItem!=NULL) && ( (pTreeCtrl->GetItemText(hItem)
==strWhoOnLine) || pTreeCtrl->GetItemText(hItem)
==strWhoOnLine.Right(strWhoOnLine.GetLength()-1) ) )
{
CImageList* m_imgList;
m_imgList=pTreeCtrl->GetImageList(TVSIL_NORMAL);
pTreeCtrl->SetImageList(m_imgList,TVSIL_NORMAL);
pTreeCtrl->SetItemImage(hItem,3,3);
}
hti=hItem;
}
GetNextItem(hti,TVGN_NEXTVISIBLE),寻找符合条件的分支。
可能我对遍历树存在误解,请教大家,谢谢HTREEITEM hti =pTreeCtrl->GetRootItem();
HTREEITEM hItem;
do
{
ExpandBranch(pTreeCtrl,hti);
}
while((hti = pTreeCtrl->GetNextSiblingItem( hti )) != NULL );hti =pTreeCtrl->GetRootItem();
while(hti)
{
hItem=pTreeCtrl->GetNextItem(hti,TVGN_NEXTVISIBLE);
if( (hItem!=NULL) && ( (pTreeCtrl->GetItemText(hItem)
==strWhoOnLine) || pTreeCtrl->GetItemText(hItem)
==strWhoOnLine.Right(strWhoOnLine.GetLength()-1) ) )
{
CImageList* m_imgList;
m_imgList=pTreeCtrl->GetImageList(TVSIL_NORMAL);
pTreeCtrl->SetImageList(m_imgList,TVSIL_NORMAL);
pTreeCtrl->SetItemImage(hItem,3,3);
}
hti=hItem;
}
解决方案 »
- 基于对话框类mfc程序
- 请问connect(...)发生SOCKET_ERROR的原因是什么
- ADO访问Access数据库,插入数据和更新数据出错
- CListCtrl类用法的一个简单问题
- 怎样截取IRDA(红外端口)的封包?谢谢!
- 如何用GDI+实现透明的PNG格式图片文件的制作输出?
- 我想知道CTRL+ALT+key是如何呼叫出一个最小化的程序的?要代码示例
- LoadLibrary() 调用失败?就是不能加载返回0,GetLastError=126(加载MFC extention DLL)
- 如何努力使代码在编译后尺寸最小
- 小问题了。。。。。
- VB里用RDO和OLE控件可以很容易的绑定显示用ACCESS插入的MDB中的ole对象(如Paint.Picture图片).如何在VC里实现?
- 疑问
hItem=pTreeCtrl->GetNextItem(hti,TVGN_NEXTVISIBLE);
VC++中如何遍历整个目录树查找文件
在应用程序的开发过程中,经常会遇到如何查找某一文件以确定此文件路径的
问题。利用CFileFind类可以比较方便地在当前目录下进行文件查找,但却不能
对其子目录中的文件进行搜寻。而实际应用中往往需要对某一整个目录树,甚
至是整个C盘或D盘驱动器进行文件搜寻。通过实践,我们在Visual C++ 6.0
中编程实现了如何遍历任意目录树,以查找某一特定的文件。 在下面的具体陈述中可以看到,在确定要查找的文件名和要进行搜索的目
录的名称后,将调用函数Search_Directory进行文件的查找。首先依次查找当
前目录下的每一个实体(文件或是子目录),如果是某一子目录,则进入该子
目录并递归调用函数Search_Dirctory进行查找,查找完毕之后, 再返回上一级
目录;如果不是子目录而是某一文件,则判断其是否就是我们要查找的文件,
如果是则输出其完整的文件路径。这样,通过Search_Directory函数的反复递
归调用,就可以实现对整个目录,包括子目录的遍历搜索。下面将举例详细讲
述如何在VC++中编程实现在整个目录树中的文件查找。 1.在Visual C++ 6.0(VC++ 5.0与之类似)中用默认方式创建了一基
于对话框的应用程序Search。在主窗口对话框上放置一命令按钮,其Caption为
“Search File”,ID为ID—BUTTON—SEARCH。单击此按钮将完成文件的查找工作。 2.利用ClassWizard为“Search File”按钮的BN_CLICKED 事件添加处理
函数OnButtonSearch,代码如下: #include 〈direct.h〉 #include 〈io.h〉 ...... void CSearchDlg::OnButtonSearch() { // TODO: Add your control notification handler code here char szFilename[80]; // 字符串 szFilename 表示要查找的文件名 strcpy(szFilename,″Mytext.txt″); _chdir(″d:\\″); // 进入要查找的路径(也可为某一具体的目录) // 查找文件, 如果查到则显示文件的路径全名 Search_Directory(szFilename); // 为CSearchDlg类的一成员函数 MessageBox(″查找文件完毕!″); // 显示查找完毕的信息 } 3.在CSearchDlg类中增加成员函数Search_Directory,它将完成具体的文
件查找工作,代码如下: void CSearchDlg::Search_Directory(char* szFilename) { long handle; struct _finddata_t filestruct; //表示文件(或目录)的信息 char path_search[_MAX_PATH]; //表示查找到的路径结果 // 开始查找工作, 找到当前目录下的第一个实体(文件或子目录), // ″*″表示查找任何的文件或子目录, filestruct为查找结果 handle = _findfirst(″*″, &filestruct); // 如果handle为-1, 表示当前目录为空, 则结束查找而返回 if((handle == -1)) return; // 检查找到的第一个实体是否是一个目录(filestruct.name为其名称) if( ::GetFileAttributes(filestruct.name) & FILE—ATTRIBUTE—DIRECTORY ) { // 如果是目录, 则进入该目录并递归调用函数Search_Dirctory进行查找, // 注意: 如果目录名的首字符为′.′(即为″.″或″..″), 则不用进行查找 if( filestruct.name[0] != ′.′ ) { —chdir(filestruct.name); Search_Directory(szFilename); // 查找完毕之后, 返回上一级目录 —chdir(″..″); } } else // 如果第一个实体不是目录, 则检查是否是要查找的文件 { // stricmp对两字符串进行小写形式的对比, 返回为0表示完全一致 if( !stricmp(filestruct.name, szFilename) ) { // 先获得当前工作目录的全路径 —getcwd(path_search,—MAX—PATH); // 再获得文件的完整的路径名(包含文件的名称) strcat(path_search,″\\″); strcat(path—search,filestruct.name); MessageBox(path_search); //输出显示 } } // 继续对当前目录中的下一个子目录或文件进行与上面同样的查找 while(!(—findnext(handle,&filestruct))) { if( ::GetFileAttributes(filestruct.name) & FILE—ATTRIBUTE—DIRECTORY ) { if(*filestruct.name != ′.′) { —chdir(filestruct.name); Search_Directory(szFilename); —chdir(″..″); } } else { if(!stricmp(filestruct.name,szFilename)) { —getcwd(path—search,—MAX—PATH); strcat(path_search,″\\″); strcat(path_search,filestruct.name); MessageBox(path_search); } } } —findclose(handle); // 最后结束整个查找工作 } 这样我们就可以对整个目录进行遍历搜索,查找某一特定的文件,并输出显
示其完整的文件路径。以上的程序在Visual C++ 6.0中已调试通过。
返回返回首页
你应该用一个循环:如果有子节点,遍历该子节点,如果没有子节点,遍历下一个兄弟节点。
不停的这样作,直到遍历完毕。我的oicq: 7267677 输入验证时请说明你的问题。
HTREEITEM hitem=NULL;CString str;
hitem=tvDept.GetRootItem ( ); //取得根節點
while(hitem){
//str=tvDept.GetItemText (hitem); AfxMessageBox (str); //測試用
Traversal(hitem);
hitem=tvDept.GetNextSiblingItem (hitem); //取得指定節點hitem的下一個兄弟節點
}
void Traversal(HTREEITEM hitem) //函數Traversal( )采用遞歸方法遍歷指定節點hitem的所有子節點
{
HTREEITEM hnext;
CString str;
hnext=tvDept.GetChildItem(hitem); //取得指定節點hitem的子節點
while(hnext){
//str=tvDept.GetItemText (hnext); AfxMessageBox (str); 此句用來調試顯示用
Traversal(hnext);
hnext=tvDept.GetNextSiblingItem (hnext); //GetPrevSiblingItem( )取兄弟節點的上一節點
}
}
{
ExpandBranch(pTreeCtrl,hti);
}
while((hti = pTreeCtrl->GetNextSiblingItem( hti )) != NULL );这段代码应当是使树视展开的,对查找没有用处
应当删除Frank_Xu的代码应当是正确的