Was viele nicht wissen bzw. vielleicht nur nicht wissen wie, ist: Wie lässt sich ein Array als Ergebnis eines Funktionsaufruf zurückgeben? Normalerweise ist der Rückgabewert einer Funktion ja meist vom Datentyp String, Long, Integer oder Boolean - wie auch immer, eben nur ein einziger Wert und keine Auflistung von Werten - ein Array eben. Wenn man nun aber den Rückgabewert der Funktion als Variant deklariert, dann kann das ja alles sein: String, Long, Integer, Boolean oder auch Array! Also geht's doch - und das sogar ganz einfach! ' Beispiel: Alle Dateien eines Ordners ' lesen und als Array zurückgeben Public Function ReadFilesFromDir(ByVal sPath As String) _ As Variant Dim sFilename As String Dim nCount As Long ReDim sFiles(0) As String If Right$(sPath, 1) <> "\" Then _ sPath = sPath & "\" nCount = 0 sFilename = Dir(sPath & "*.*", vbNormal) While sFilename <> "" If sFilename <> "." And sFilename <> ".." Then ReDim Preserve sFiles(nCount) sFiles(nCount) = sFilename nCount = nCount + 1 End If sFilename = Dir Wend ReadFilesFromDir = sFiles End Function Der Funktionsaufruf selbst sieht dann so aus: Dim sPath As String Dim I As Integer Dim sFiles As Variant sPath = "C:\Dokumente" sFiles = ReadFilesFromDir(sPath) ' Anzeige der gefundenen Dateien ' in einer ListBox If sFiles(0) <> "" Then For I = 0 To UBound(sFiles) List1.AddItem sFiles(I) Next I End If Solch eine Funktion lässt sich natürlich auch in einer Klasse verwenden, die dann z.B. als ActiveX-DLL in das Projekt eingebunden wird. Dies aber nur am Rande... Dieser Tipp wurde bereits 37.955 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
Neu! sevPopUp 2.0 Dynamische Kontextmenüs! Erstellen Sie mit nur wenigen Zeilen Code Kontextmenüs dynamisch zur Laufzeit. Vordefinierte Styles (XP, Office, OfficeXP, Vista oder Windows 8) erleichtern die Anpassung an die eigenen Anwendung... Tipp des Monats Mai 2024 Hermann Röttger Wochentage eines Datumsbereichs ermitteln Wochentage eines Datumsbereichs ermitteln, optional mit Feiertagsberechnung Access-Tools Vol.1 Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |