为了正常的体验网站,请在浏览器设置里面开启Javascript功能!
首页 > 利用VB函数Dir()实现递归搜索目录

利用VB函数Dir()实现递归搜索目录

2018-03-09 4页 doc 19KB 26阅读

用户头像

is_963767

暂无简介

举报
利用VB函数Dir()实现递归搜索目录利用VB函数Dir()实现递归搜索目录 indoc.in 利用VB函数Dir()实现递归搜索目录 我在很久以前就实现了这个方法了。它没有采用任何的控件形式,也 没有调用系统API函数FindFirst,FindNext进行递归调用,和别人有点不 同的就是我用的是VB中的Dir()函数。事实上,直接采用Dir()函数是不能 进行自身的递归的调用的,但我们可以采用一种办法把Dir将当前搜索目录 的子目录给保存下来,然后在自身的search(strPathName)递归函数中依次 进行递归的调用,这样就可以把指定的目录搜索完毕...
利用VB函数Dir()实现递归搜索目录
利用VB函数Dir()实现递归搜索 indoc.in 利用VB函数Dir()实现递归搜索目录 我在很久以前就实现了这个了。它没有采用任何的控件形式,也 没有调用系统API函数FindFirst,FindNext进行递归调用,和别人有点不 同的就是我用的是VB中的Dir()函数。事实上,直接采用Dir()函数是不能 进行自身的递归的调用的,但我们可以采用一种办法把Dir将当前搜索目录 的子目录给保存下来,然后在自身的search(strPathName)递归函数中依次 进行递归的调用,这样就可以把指定的目录搜索完毕。 具体代码如下: ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' '函数GetExtName '功能:得到文件后缀名(扩展名) '输入:文件名 '输出:文件后缀名(扩展名) ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' Public Function GetExtName(strFileName As String) As String Dim strTmp As String Dim strByte As String Dim i As Long For i = Len(strFileName) To 1 Step -1 strByte = Mid(strFileName, i, 1) If strByte <> "." Then strTmp = strByte + strTmp Else Exit For End If Next i GetExtName = strTmp End Function Public Function search(ByVal strPath As String, Optional strSearch As String = "") As Boolean Dim strFileDir() As String Dim strFile As String 文章内容版权归原作者所有 VICHU.NET indoc.in Dim i As Long Dim lDirCount As Long On Error GoTo MyErr If Right(strPath, 1) <> "\" Then strPath = strPath + "\" strFile = Dir(strPath, vbDirectory Or vbHidden Or vbNormal Or vbReadOnly) While strFile <> "" '搜索当前目录 DoEvents If (GetAttr(strPath + strFile) And vbDirectory) = vbDirectory Then '如果找到的是目录 If strFile <> "." And strFile <> ".." Then '排除掉父目录(..)和当前目录(.) lDirCount = lDirCount + 1 '将目录数增1 ReDim Preserve strFileDir(lDirCount) As String strFileDir(lDirCount - 1) = strFile '用动态数组保存当前目录名 End If Else If strSearch = "" Then Form1.List1.AddItem strPath + strFile ElseIf LCase(GetExtName(strPath + strFile)) = LCase(GetExtName(strSearch)) Then '满足搜索条件,则处理该文件 Form1.List1.AddItem strPath + strFile '将文件全名保存至列框List1中 End If End If strFile = Dir Wend For i = 0 To lDirCount - 1 Form1.Label3.Caption = strPath + strFileDir(i) Call search(strPath + strFileDir(i), strSearch) '递归搜索子目录 Next ReDim strFileDir(0) '将动态数组清空 search = True '搜索成功 Exit Function MyErr: search = False '搜索失败 End Function 文章内容版权归原作者所有 VICHU.NET
/
本文档为【利用VB函数Dir()实现递归搜索目录】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
热门搜索

历史搜索

    清空历史搜索