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 33.097 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. |
vb@rchiv CD Vol.6 ![]() ![]() Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! Online-Update-Funktion Entwickler-Vollversionen u.v.m. Tipp des Monats ![]() Matthias Kozlowski Umlaute konvertieren Ersetzt die Umlaute in einer Zeichenkette durch die entsprechenden Doppelbuchstaben (aus ä wird ae, usw.) sevAniGif (VB/VBA) ![]() Anzeigen von animierten GIF-Dateien Ab sofort lassen sich auch unter VB6 und VBA (Access ab Version 2000) animierte GIF-Grafiken anzeigen und abspielen, die entweder lokal auf dem System oder auf einem Webserver gespeichert sind. |
||||||||||||||||
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. |