Das Ermitteln aller Dateien eines Ordners lässt sich sehr einfach über die VB-eigene Funktion Dir erledigen. Jedoch sind die ermittelten Dateien immer alphabetisch sortiert. Wie sieht es aber aus, wenn die Dateien nach Datum / Uhrzeit sortiert angezeigt werden sollen? Wir behelfen uns eines kleinen Tricks Und genau das wollten wir ja auch erreichen! Dim sFile As String Dim sPath As String Dim sFileDate As Variant Dim lMax As Long Dim lCount As Long ReDim aFiles(1 To 1) As String ' Pfad (Verzeichnis) sPath = "d:\temp\" ' Array: aktuelle Größe der Dimension lMax = UBound(aFiles) ' alle Dateien im angegebenen Ordner ermitteln sFile = Dir$(sPath & "*.*") While sFile <> "" If sFile <> "." And sFile <> ".." Then ' Dateizeit ermitteln sFileDate = FileDateTime(sPath & sFile) ' Array dynamisch vergrößern ' siehe Tipps & Tricks lCount = lCount + 1 If lCount > lMax Then lMax = lCount * 2 ReDim Preserve aFiles(1 To lMax) End If ' wir stellen dem Dateinamen die Zeitangabe voran, ' so daß die spätere Sortierung via QuickSort ' die Dateien nach Datum sortiert aFiles(lCount) = Format$(sFileDate, _ "yyyymmdd hhnnss") & sFile End If sFile = Dir$ Wend ' Array: überflüssigen Speicher freigeben lMax = lCount ReDim Preserve aFiles(1 To lMax) ' Array via Quicksort sortieren QuickSort aFiles() ' sortierte Anzeige der Dateien in einer ListBox ' (nach Datum sortiert - wohlgemerkt ;-)) For lCount = lMax To 1 Step -1 List1.AddItem Mid$(aFiles(lCount), 16) Next lCount Die "Übertragung" des sortierten Arrays erfolgt rückwärts, so daß in der Liste die Datei mit dem neuesten Datum ganz oben steht. Den Code für den QuickSort-Algorithmus finden Sie hier: Dieser Tipp wurde bereits 32.290 mal aufgerufen.
Anzeige
![]() ![]() ![]() (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 ![]() Dieter Otter Beliebige Zeichen am Anfang und Ende eines Strings entfernen Mit der Trim-Funktion lassen sich nicht nur Leerzeichen, sondern bei Bedarf auch beliebige Zeichen entfernen. 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. |