| |

Visual-Basic EinsteigerDateien im Filesystem löschen. | |  | Autor: Mr_c&b | Datum: 20.10.03 09:53 |
| Moin alle zusammen,
ich habe da ein kleines Script geproggt, welches die Dateien eines Verzeichnisses nach X Tagen verchiebt und danach nochmals nach X Tagen löscht.
Nun brauche ich die Funktion noch für Unterverzeichnisse, zum einen das die Dateien innerhalb dieser Unterverzeichnisse mit dem Alter von X Tagen verschoben werden.
Die Deluse Ausführung wäre dann noch wenn die Unterverzeichnisse leer sind, das diese ebenfalls gelöscht werden.
Wäre super wenn mir jemand helfen könnte! Anbei mein jetziges Script!
Vielen dank schonmal für jede Hilfe!
'*** Anzahl der Dateien im Ordner ermitteln
set fs = CreateObject("Scripting.FileSystemObject")
set ordner = fs.GetFolder("D:\Users\Transfer\")
anz_dateien = ordner.Files.Count
anz_unterordner = ordner.SubFolders.Count
'*** aktuelles Datum bestimmen
akt_datum = (now)
'***Überprüfen, ob die Protokolldatei bereitsexistiert,
'***wenn nicht anlegen
set logdatei = fs.OpenTextFile("D:\_logs\transfer.txt",8,true)
'*** Wenn mindestens eine Datei vorhanden ist
If not anz_dateien = "0" Then
'*** Jede Datei der Reihe nach überprüfen
For each datei in ordner.Files
'*** Dateiname auslesen
name = datei.name
'*** Erstelldatum auslesen, und in Datum und Uhrzeit zerlegen
Erstelldatum = datei.DateCreated
'*** Überprüfen ob bereits 120 Stunden vergangen sind
diff = DateDiff("h",erstelldatum, akt_datum)
If diff > 120 Then
'***File löschen
fs.CopyFile "D:\Users\Transfer\" & name, "D:\_move\" & name
fs.DeleteFile "D:\Users\Transfer\" & name
'***Protokolleintrag erzeugen
eintrag = akt_datum & vbTab & "Dateiname: " & name & vbTab & "Erstelldatum: " & Erstelldatum & vbTab & "Dateialter (h): " & diff
logdatei.WriteLine(eintrag)
End if
Next
logdatei.Close
End if
End if
'***Überprüfen, ob die Protokolldatei bereitsexistiert,
'***wenn nicht anlegen
set ordner_move = fs.GetFolder("D:\_move")
anz_move_dateien = ordner_move.Files.Count
set logdatei = fs.OpenTextFile("D:\_logs\movelogs\transfer_del.txt",8,true)
If not anz_move_dateien = "0" Then
For each datei in ordner_move.Files
name = datei.name
Erstelldatum = datei.DateCreated
diff = DateDiff("h",erstelldatum, akt_datum)
If diff >240 Then
'***File löschen
fs.DeleteFile "D:\_move\" & name
'***Protokolleintrag erzeugen
move_eintrag = akt_datum & vbTab & "Dateiname: " & name & vbTab & "Erstelldatum :" & Erstelldatum & vbTab & "Dateialter (h):" & diff
logdatei.WriteLine(move_eintrag)
end if
next
logdatei.Close
end if |  |
 | Sie sind nicht angemeldet! Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.
Einloggen | Neu registrieren |
  |
|
vb@rchiv CD Vol.6 vb@rchiv Vol.6
Geballtes Wissen aus mehr als 8 Jahren vb@rchiv!
Online-Update-Funktion Entwickler-Vollversionen u.v.m.Jetzt zugreifen Tipp des Monats Oktober 2025 Matthias KozlowskiUmlaute konvertierenErsetzt die Umlaute in einer Zeichenkette durch die entsprechenden Doppelbuchstaben (aus ä wird ae, usw.) 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... Weitere Infos
|
|
|
Copyright ©2000-2025 vb@rchiv Dieter Otter Alle Rechte vorbehalten.
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.
Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel
|
|