Option Explicit
Public Type BROWSEINFO
hOwner As Long
pidlRoot As Long
pszDisplayName As String
lpszTitle As String
ulFlags As Long
lpfn As Long
lParam As Long
iImage As Long
End Type
Declare Function SHGetPathFromIDList Lib "shell32.dll" _
Alias "SHGetPathFromIDListA" (ByVal pidl As Long,
ByVal pszPath As String) As Long
Declare Function SHBrowseForFolder Lib "shell32.dll" _
Alias "SHBrowseForFolderA" (lpBrowseInfo As BROWSEINFO)
As Long
Function GetDirectory(Optional Msg As String) As String
Dim bInfo As BROWSEINFO
Dim Path As String
Dim r As Long, x As Long, pos As Integer
bInfo.pidlRoot = 0&
If IsMissing(Msg) Then
bInfo.lpszTitle = "Wählen Sie bitte einen Ordner
aus."
Else
bInfo.lpszTitle = Msg
End If
bInfo.ulFlags = &H1
x = SHBrowseForFolder(bInfo)
Path = Space$(512)
r = SHGetPathFromIDList(ByVal x, ByVal Path)
If r Then
pos = InStr(Path, Chr$(0))
GetDirectory = Left(Path, pos - 1)
Else
GetDirectory = ""
End If
End Function
Sub FileNamePath()
Dim strAdr As String
strAdr = GetDirectory
MsgBox strAdr
Range("a1") = strAdr
Dim erg As String
erg = Shell("C:\WINNT\system32\cmd.exe", 1)
Application.Wait (Now + TimeValue("0:00:01"))
SendKeys "tree", True
SendKeys "{enter}", True
End Sub
ich möchte jetzt den Pfad der in der Variablen strAdr
gespeichert ist (könnte z.B. so aussehen: C:\Eingene Dateien) in die DOS-Shell bringen um dann
anschließend von diesem Verzeichnis ( C:\Eigenen Dateien ) aus den tree-Befehl
absetzen zu können.
Kann mir jemand eine Lösung für dieses Problem sagen?
Gruss und Danke
Martin