GetOpenFilename-Methode: Bestimmte Dateien auswählen
Schritt-für-Schritt-Anleitung
Um in Excel mittels VBA die GetOpenFilename-Methode zu verwenden und nur bestimmte Dateien anzuzeigen, gehe folgendermaßen vor:
-
Öffne den VBA-Editor: Drücke ALT + F11.
-
Füge ein neues Modul hinzu: Rechtsklicke im Projektfenster und wähle Einfügen > Modul.
-
Gib den folgenden Code ein:
Private Sub CommandButton1_Click()
Dim fileToOpen As String
ChDrive ThisWorkbook.Path
ChDir ThisWorkbook.Path
fileToOpen = Application.GetOpenFilename("Excel File (JAP*.xls),JAP*.xls,Excel File(*.xls),*.xls")
If fileToOpen <> False Then
MsgBox "Ausgewählte Datei: " & fileToOpen
End If
End Sub
-
Passe den Filter an: Ändere die Filterkriterien im GetOpenFilename-Aufruf, um nur die gewünschten Excel-Dateien anzuzeigen.
-
Führe das Makro aus: Klicke auf den CommandButton im Formular.
Häufige Fehler und Lösungen
Alternative Methoden
Falls die GetOpenFilename-Methode nicht die gewünschten Ergebnisse liefert, kannst du die Windows-API-Funktion GetOpenFileName verwenden. Hier ein Beispiel:
Private Declare Function GetOpenFileName Lib "comdlg32.dll" Alias "GetOpenFileNameA" (pOpenfilename As OPENFILENAME) As Long
Private Type OPENFILENAME
lStructSize As Long
hwndOwner As Long
hInstance As Long
lpstrFilter As String
lpstrCustomFilter As String
nMaxCustFilter As Long
nFilterIndex As Long
lpstrFile As String
nMaxFile As Long
lpstrFileTitle As String
nMaxFileTitle As Long
lpstrInitialDir As String
lpstrTitle As String
Flags As Long
nFileOffset As Integer
nFileExtension As Integer
lpstrDefExt As String
lCustData As Long
lpfnHook As Long
lpTemplateName As Long
End Type
Mit dieser Methode kannst du spezifische Dateifilter und Dialogoptionen anpassen.
Praktische Beispiele
Hier sind zwei Beispiele, um spezifische Excel-Dateien auszuwählen:
-
Filter für bestimmte Dateinamen:
fileToOpen = Application.GetOpenFilename("Excel File (JAP*.xls),JAP*.xls")
-
Mehrfachauswahl aktivieren:
fileToOpen = Application.GetOpenFilename("Excel Files (*.xls), *.xls", , "Wähle eine Datei", , True)
Beachte, dass das Multiselect-Feature nur funktioniert, wenn True als letzten Parameter übergeben wird.
Tipps für Profis
-
Verwendung von ChDrive und ChDir: Diese Befehle helfen dabei, das aktuelle Verzeichnis vor dem Öffnen der Datei festzulegen. So kannst du sicherstellen, dass der Dialog im richtigen Ordner startet.
-
Fehlerbehandlung: Füge eine Fehlerbehandlung in dein Makro ein, um unerwartete Situationen abzufangen. Zum Beispiel:
On Error Resume Next
-
Dokumentation: Halte deine VBA-Codes gut dokumentiert, um später schnell Anpassungen vornehmen zu können.
FAQ: Häufige Fragen
1. Wie kann ich mehrere Dateien auswählen?
Um mehrere Dateien auszuwählen, setze den letzten Parameter in der GetOpenFilename-Methode auf True.
2. Funktioniert die GetOpenFilename-Methode in allen Excel-Versionen?
Ja, die GetOpenFilename-Methode ist in den meisten Versionen von Excel verfügbar, allerdings können einige Funktionen je nach Version variieren. Achte darauf, dass deine Excel-Version aktuell ist.