通用对话框能打开单个文件和多个文件,但是如何才能通过通用对话框打开文件夹呢,就像用文件夹控件打开文件夹那样?

解决方案 »

  1.   

    Private Type BrowseInfo
        hWndOwner As Long
        pIDLRoot As Long
        pszDisplayName As Long
        lpszTitle As Long
        ulFlags As Long
        lpfnCallback As Long
        lParam As Long
        iImage As Long
    End Type
    Const BIF_RETURNONLYFSDIRS = 1
    Const MAX_PATH = 260
    Private Declare Sub CoTaskMemFree Lib "ole32.dll" (ByVal hMem As Long)
    Private Declare Function lstrcat Lib "kernel32" Alias "lstrcatA" (ByVal lpString1 As String, ByVal lpString2 As String) As Long
    Private Declare Function SHBrowseForFolder Lib "shell32" (lpbi As BrowseInfo) As Long
    Private Declare Function SHGetPathFromIDList Lib "shell32" (ByVal pidList As Long, ByVal lpBuffer As String) As Long
    Private Sub Form_Load()    Dim iNull As Integer, lpIDList As Long, lResult As Long
        Dim sPath As String, udtBI As BrowseInfo    With udtBI
            'Set the owner window
            .hWndOwner = Me.hWnd
            'lstrcat appends the two strings and returns the memory address
            .lpszTitle = lstrcat("C:\", "")
            'Return only if the user selected a directory
            .ulFlags = BIF_RETURNONLYFSDIRS
        End With    'Show the 'Browse for folder' dialog
        lpIDList = SHBrowseForFolder(udtBI)
        If lpIDList Then
            sPath = String$(MAX_PATH, 0)
            'Get the path from the IDList
            SHGetPathFromIDList lpIDList, sPath
            'free the block of memory
            CoTaskMemFree lpIDList
            iNull = InStr(sPath, vbNullChar)
            If iNull Then
                sPath = Left$(sPath, iNull - 1)
            End If
        End If    MsgBox sPath
    End Sub
      

  2.   

    以下代码是打印程序所在目录下的所有文件名,你改一下路径就可以:Private Sub Command1_Click()
        Dim iFileCount As Integer
        Dim tmpFile As String
        Dim strDir As String
        
        '指定目录的路径
        strDir = App.Path
        If Not (Right(strDir, 1) = "\") Then
            strDir = strDir & "\"
        End If
        
        tmpFile = ""
        iFileCount = 0
        
        '遍历 strDir 文件的数目,并将文件名赋给tmpFile
        tmpFile = Dir(strDir)
        Do While (Len(tmpFile) <> 0)
            Debug.Print tmpFile         '在立即窗口打印文件名称,也可以进行另外的处理
            iFileCount = iFileCount + 1
            tmpFile = Dir()
        Loop
    End Sub