Re: Speicherort abfragen
14.05.2003 15:35:32
Umbratus
Hallo HansJörgDu kannst mit dieser Schleife den Namen von rechts her durchgehen, wenn ein Backslash kommt, schneidest du die linke Hälfte vom string ab.
For i = Len(dName) To 1 Step -1
If Mid(dName, i, 1) = "\" Then
pfad = Left(dName, i)
Exit For
End If
Next i
Natürlich könntest du auch einen Dialog benutzen, um ein Verzeichnis auszuwählen, sowas etwa:
'API-Funktionen für Verzeichnis-Auswahl
'**************************************
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
Die Funktion an sich, also aufzurufen : dName = Getdirectory dann geht der Dialog auf....
*************************************************************************************************
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
Gruß Umbratus