vbs - Dateien löschen die älter als n-Tage sind
Ein Hallo in die Runde,
meine Ziel ist es, eine vbs zu erstellen, die alle Dateien die älter sind als 19 Monate löscht.
Nun habe ich hier im Forum einen Code gefunden und abgewandelt:
Da ich delage32, autoit und andere Drittprogramme nicht nutzen kann, würde ich dies gern mit vbs probieren.
Ich vermute, dass der Fehler by "set myFiles" liegen könnte. Hier stand im Original myFolder.Files. Ich habe das auch in der Variante "J:\test.*" probiert funktioniert leider auch nicht.
Nachdem ich zum Thema Kopieren mittels batch hier im Forum hervorragende Hilfe erfahren habe, hoffe ich, dass es auch hierzu ein Hinweis gegeben werden kann.
Ich bedanke mich ganz herzlich im voraus.
Cu Koido
meine Ziel ist es, eine vbs zu erstellen, die alle Dateien die älter sind als 19 Monate löscht.
Nun habe ich hier im Forum einen Code gefunden und abgewandelt:
Set myArguments = WScript.Arguments
If myArguments.Count <> 1 Then
call DisplayInfo
Wscript.Quit (1)
End if
Dim heute, olddate
heute = FormatDateTime(Date, 2)
olddate = DateAdd("d", -270, heute)
set objFS = CreateObject("Scripting.FilesystemObject")
set myFolder = objFS.GetFolder(myArguments(0))
set myFiles = "J:\ test"
for each myfile in myFiles
If myFile.DateModified < olddate then
myFile.Delete
end if
next
Sub DisplayInfo
MsgBox "Usage: delmyordner.vbs [FolderPath]", vbExclamation, "Missing Argument"
End Sub
Da ich delage32, autoit und andere Drittprogramme nicht nutzen kann, würde ich dies gern mit vbs probieren.
Ich vermute, dass der Fehler by "set myFiles" liegen könnte. Hier stand im Original myFolder.Files. Ich habe das auch in der Variante "J:\test.*" probiert funktioniert leider auch nicht.
Nachdem ich zum Thema Kopieren mittels batch hier im Forum hervorragende Hilfe erfahren habe, hoffe ich, dass es auch hierzu ein Hinweis gegeben werden kann.
Ich bedanke mich ganz herzlich im voraus.
Cu Koido
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 121567
Url: https://administrator.de/contentid/121567
Ausgedruckt am: 23.11.2024 um 01:11 Uhr
9 Kommentare
Neuester Kommentar
Hallo Koido1!
Versuchs mal damit (ungetestet):
Gruß Dieter
[edit] Fehler korrigiert und Test Folder hinzugefügt [/edit]
Versuchs mal damit (ungetestet):
Dim myArguments, objFS, myFolder, myFile, olddate
Set myArguments = WScript.Arguments
If myArguments.Count <> 1 Then Call DisplayInfo: Wscript.Quit (1)
olddate = DateAdd("m", -19, Now) '19 Monate
set objFS = CreateObject("Scripting.FilesystemObject")
If Not objFS.FolderExists(myArguments(0)) Then Call DisplayInfo: Wscript.Quit (1)
set myFolder = objFS.GetFolder(myArguments(0))
for each myfile in myFolder.Files
If myFile.DateLastModified < olddate then objFS.DeleteFile myFile.Path
next
Sub DisplayInfo
MsgBox "Usage: delmyordner.vbs [FolderPath]", vbExclamation, "Missing Argument"
End Sub
Gruß Dieter
[edit] Fehler korrigiert und Test Folder hinzugefügt [/edit]
Hallo Koido1!
Code oben geändert.
Den Fehler myFile.Delete habe ich leider übersehen
Zusätzlich habe ich noch den Test FolderExists hinzugefügt.
Die Pfadangabe musst in Deinem Code als Argument übergeben. Wenn Du möchtest, kann man eine Abfrage per InputBox machen?
Gruß Dieter
Code oben geändert.
Den Fehler myFile.Delete habe ich leider übersehen
Zusätzlich habe ich noch den Test FolderExists hinzugefügt.
Die Pfadangabe musst in Deinem Code als Argument übergeben. Wenn Du möchtest, kann man eine Abfrage per InputBox machen?
Gruß Dieter
Hallo Koido1!
Also, am Code änderst Du nichts.
Mit Argument bedeutet, dass Du beim Aufruf des Scripts ein Argument mit übergibst: z.B.: Test.Vbs x:\test
Aber vielleicht doch besser mit einer Abfrage, wie in diesem Code:
Den Text in der InputBox kannst Du natürlich ändern. Erstelle einen Test-Ordner zum Testen.
Nach dem Starten des Scripts *.vbs:
1. Erscheint eine Eingabe-Box mit der Pfadabfrage
2. Ist die Pfadangabe Leer oder wird abgebrochen, erscheint die MsgBox und das Script wird beendet.
3. Existiert der Ordner nicht, dann passiert das gleiche wie unter Punkt 2 beschrieben.
Bei der Eingabe kann leider nicht unterschieden werden, ob eine Leer-Eingabe oder ein Abrechen erfolgt ist, daher wird in beiden Fällen die MsgBox ausgegeben und das Script mit Errorlevel 1 beendet. Ansonsten gibt das Script Errorlevel 0 zurück. Errorlevel kann z.B. in einer Batch entsprechend ausgewertet werden.
Noch Fragen?
Gruß Dieter
Also, am Code änderst Du nichts.
Mit Argument bedeutet, dass Du beim Aufruf des Scripts ein Argument mit übergibst: z.B.: Test.Vbs x:\test
Aber vielleicht doch besser mit einer Abfrage, wie in diesem Code:
Dim objFS, myPath, myFolder, myFile, olddate
myPath = InputBox("Bitte Pfad eingeben:", "Dateien älter als 19 Monate löschen")
If myPath = "" Then Call DisplayInfo: Wscript.Quit (1)
set objFS = CreateObject("Scripting.FilesystemObject")
If Not objFS.FolderExists(myPath) Then Call DisplayInfo: Wscript.Quit (1)
set myFolder = objFS.GetFolder(myPath)
olddate = DateAdd("m", -19, Now) '19 Monate
for each myfile in myFolder.Files
If myFile.DateLastModified < olddate then objFS.DeleteFile myFile.Path
next
Wscript.Quit (0)
Sub DisplayInfo
MsgBox "Usage: delmyordner.vbs [FolderPath]", vbExclamation, "Missing Argument"
End Sub
Den Text in der InputBox kannst Du natürlich ändern. Erstelle einen Test-Ordner zum Testen.
Nach dem Starten des Scripts *.vbs:
1. Erscheint eine Eingabe-Box mit der Pfadabfrage
2. Ist die Pfadangabe Leer oder wird abgebrochen, erscheint die MsgBox und das Script wird beendet.
3. Existiert der Ordner nicht, dann passiert das gleiche wie unter Punkt 2 beschrieben.
Bei der Eingabe kann leider nicht unterschieden werden, ob eine Leer-Eingabe oder ein Abrechen erfolgt ist, daher wird in beiden Fällen die MsgBox ausgegeben und das Script mit Errorlevel 1 beendet. Ansonsten gibt das Script Errorlevel 0 zurück. Errorlevel kann z.B. in einer Batch entsprechend ausgewertet werden.
Noch Fragen?
Gruß Dieter
Hallo Koido1!
Yep, gern geschehen
Gruß Dieter
Yep, gern geschehen
Gruß Dieter
Hall Koido!
Also, Ich bin mir nicht sicher, ob Du weißt, dass es sich bei "DateLastModified" um das letzte
Änderungsdatum handelt. Falls Du aber das Erstellungsdatum verwenden möchtest, dann
ersetze "DateLastModified" durch "DateCreated"
Gruß Dieter
Also, Ich bin mir nicht sicher, ob Du weißt, dass es sich bei "DateLastModified" um das letzte
Änderungsdatum handelt. Falls Du aber das Erstellungsdatum verwenden möchtest, dann
ersetze "DateLastModified" durch "DateCreated"
Gruß Dieter