retrodude
Goto Top

Inhalt von Unterordnern löschen VBScript Prozedur

Hallo Zusammen

Ich habe folgenden Code um den Inhalt von Verzeichnissen zu löschen. Wie muss ich den Code erweitern, damit ich in dem Pfad den Inhalt sämtlicher Unterordner löschen kann? Die Unterordner also bestehen bleiben?
z.B.:
D:\Folder\1\"zu löschender Inhalt"
D:\Folder\2\"zu löschender Inhalt"
..
etc.

Gruss und Dank im Voraus!
Dim fso
Set fso = CreateObject("Scripting.FileSystemObject")  

strPath = "D:\Folder"  

Delete strPath

Sub Delete(StrFolder)
On Error Resume Next
Dim Folder
Set Folder = fso.GetFolder(StrFolder)

For Each SubFolder in Folder.SubFolders
Delete SubFolder
If Folder.Attributes And 1 Then
Folder.Attributes = Folder.Attributes - 1
End If
SubFolder.Delete
Next

For Each File In Folder.Files
If File.Attributes And 1 Then
File.Attributes = File.Attributes - 1
End If
File.Delete
Next
End Sub

Content-ID: 173509

Url: https://administrator.de/contentid/173509

Ausgedruckt am: 22.11.2024 um 21:11 Uhr

RetroDude
RetroDude 22.09.2011 um 14:52:13 Uhr
Goto Top
Ich habe mir bereits etwas Gedanken gemacht und sehe folgenden Lösungsweg:

1. Die Namen sämtlicher Unterverzeichnisse einlesen und diese in einem Array ablegen.
2. Den Array durchzählen und die Anzahl Iterationen inkl. Array dem Sub übergeben.

Kann mir bei der Umsetzung meines Plans jemand unter die Arme greifen? Oder ist dieser Ansatz nicht tauglich?

Thanx!
bastla
bastla 22.09.2011 um 15:15:53 Uhr
Goto Top
Hallo RetroDude!

Du hast doch bereits Rekursion in Deinem (leider noch nicht als Code ) Ansatz - dann sollte doch eigentlich etwas in der Art reichen:
Set fso = CreateObject("Scripting.FileSystemObject")  

strPath = "D:\Folder"  

Delete strPath

Sub Delete(StrFolder)
On Error Resume Next
Set Folder = fso.GetFolder(StrFolder)
For Each SubFolder in Folder.SubFolders
    fso.DeleteFile SubFolder.Path & "\*.*", True  
    Delete SubFolder
Next
End Sub
Eine Anmerkung zur Variablendeklaration in VBS: Wenn Du schon "Dim" verwendest, dann aber auch konsequent für alle vorkommenden Variablen und zusammen mit "Option Explicit" - ansonsten kannst Du sie auch gleich einsparen ...

Grüße
bastla
RetroDude
RetroDude 22.09.2011 um 15:36:52 Uhr
Goto Top
Hallo Bastla

Danke für den Hinweis wegen der Formatierung. Habe es ausprobiert. So löscht er zwar die Files auf erster Ebene. Die Unterordner der Unterordner lässt er aber stehen. Dementsprechend auch deren Inhalt. Was muss ich ändern, daimt er sämtlichen Inhalt der Unterordner des entsprechenden Ordners löscht?

Danke und Gruss
bastla
bastla 22.09.2011 um 15:49:46 Uhr
Goto Top
Hallo RetroDude!

Das hatte ich anders verstanden ...

Wenn Du die erste Unterordner-Ebene erhalten, aber alle Inhalte entfernen willst, dann einfach so:
Set fso = CreateObject("Scripting.FileSystemObject")  

strPath = "D:\Folder"  

Set Folder = fso.GetFolder(strPath)
For Each SubFolder in Folder.SubFolders
    fso.DeleteFile SubFolder.Path & "\*.*", True  
    fso.DeleteFolder SubFolder.Path & "\*.*", True  
Next
Grüße
bastla
RetroDude
RetroDude 22.09.2011 um 16:02:20 Uhr
Goto Top
Danke Bastla

Funktioniert bestens. Ich hätte noch ne kleine Frage. Was müsste ich hizufügen, damit im Verzeichnis D:\Folder, in dem ja nur die Ordner bereinigt werden, zusätzlich sämtliche Dateien gelöscht würden?

Gruss und Danke nochmals!
bastla
bastla 22.09.2011 um 16:31:24 Uhr
Goto Top
Hallo RetroDude!

Wenn Du die Zeile 7 betrachtest, und unter Berücksichtigung der Tatsache, dass Du den Pfad gar nicht ermitteln musst, weil er bereits in "strPath" steht, könntest Du das vielleicht auch selbst schaffen ...

Grüße
bastla
RetroDude
RetroDude 22.09.2011 um 16:34:54 Uhr
Goto Top
Hast recht.

fso.DeleteFile strPath & "\*.*", True

gell?

Gruss face-wink
ovu-p86
ovu-p86 23.09.2011 um 03:15:46 Uhr
Goto Top
Hallo RetroDude,

hier nochmal eine Lösung mit einem "cmd".
cd /d D:\Folder && del /a /s /f /q *.*
erfüllt den gleichen Zweck.

Jetzt bekomme ich bestimmt Haue weil nach einem VB-Script gefragt wurde. Aber das ist ja eine Alternative.


Gruß
Uwe
RetroDude
RetroDude 23.09.2011 um 09:11:13 Uhr
Goto Top
Hallo Uwe

Danke für den Input. Ich bin stets offen für konstruktive Vorschläge. Deiner gehört zu diesen. Lass Dich nicht von frustrierten Mitgliedern von diesem Pfad abbringen. Solche Beiträge sind eine Bereicherung für einen Thread. Viele Wege führen ja bekanntlich nach Rom.

Gruss und schönes Wochenende!

Retrodude
bastla
bastla 23.09.2011 um 14:50:58 Uhr
Goto Top
@ovu-p86
Jetzt bekomme ich bestimmt Haue weil nach einem VB-Script gefragt wurde.
Die Haue gibt's dafür, dass Du
Die Unterordner der Unterordner lässt er aber stehen.
ignoriert hast ... face-wink
@RetroDude
Wenn CMD tatsächlich eine Option ist, dann:
@echo off & setlocal
set "Pfad=D:\Folder"  

del /a /f /q "%Pfad%\*.*"  
for /d %%i in ("%Pfad%\*.*") do (  
    for /d %%u in ("%%~i\*.*") do rd /s /q "%%u"  
    del /a /f /q "%%i\*.*"  
)
Grüße
bastla
ovu-p86
ovu-p86 23.09.2011 um 23:29:33 Uhr
Goto Top
Hallo Bastla,

das habe ich in der Tat ignoriert. Hatte das so mißverstanden, daß kurz gesagt: alle Dateien gelöscht, aber die komplette Ordnerstruktur erhalten bleiben soll. Und nur das mein cmd.

Das mit "der Haue" hab ich nur geschrieben, weil meiner Ansicht nach, das Klima im Forum in letzter Zeit rauer geworden war.

Ansonsten nochmal meine Hochachtung für dich. Hab viel von dir, deinen Beiträgen lernen können. Du hast mir auch schon häufiger effektiv direkt geholfen. Und das auch mit guten, nachvollziehbaren Erklärungen. - Danke -

In diesem Sinne

Gruß
Uwe
bastla
bastla 24.09.2011 um 13:12:52 Uhr
Goto Top
Hallo ovu-p86!
Hab viel von dir, deinen Beiträgen lernen können.
Danke face-smile - aber das meiste davon habe ich selbst erst hier gelernt / verbessert ...

Grüße
bastla