Wie lösche ich alle Dateien und Ordner in einem Verzeichnis?

662

Wie kann ich mit C # alle Dateien und Ordner aus einem Verzeichnis löschen und trotzdem das Stammverzeichnis behalten?

J L.
quelle
11
Was wäre schön, wenn DirectoryInfo eine Methode wie .Clean () hätte;
JL.
6
oder .DeleteFolders- und DeleteFiles-Methoden.
JL.
18
Sie möchten wissen, dass Ihre Löschvorgänge sehr leicht eine Ausnahme auslösen können, wenn eine Datei gesperrt ist (oder wenn Sie keine Rechte haben). Eine Liste der Ausnahmen finden Sie in FileInfo.Delete.
Shane Courtrille

Antworten:

831
System.IO.DirectoryInfo di = new DirectoryInfo("YourPath");

foreach (FileInfo file in di.GetFiles())
{
    file.Delete(); 
}
foreach (DirectoryInfo dir in di.GetDirectories())
{
    dir.Delete(true); 
}

Wenn Ihr Verzeichnis möglicherweise viele Dateien enthält, EnumerateFiles()ist dies effizienter als GetFiles(), da Sie bei Verwendung EnumerateFiles()mit der Aufzählung beginnen können, bevor die gesamte Sammlung zurückgegeben wird, GetFiles()anstatt die gesamte Sammlung in den Speicher zu laden, bevor Sie mit der Aufzählung beginnen. Sehen Sie dieses Zitat hier :

Wenn Sie mit vielen Dateien und Verzeichnissen arbeiten, kann EnumerateFiles () daher effizienter sein.

Gleiches gilt für EnumerateDirectories()und GetDirectories(). Der Code wäre also:

foreach (FileInfo file in di.EnumerateFiles())
{
    file.Delete(); 
}
foreach (DirectoryInfo dir in di.EnumerateDirectories())
{
    dir.Delete(true); 
}

Für die Zwecke dieser Frage gibt es wirklich keinen Grund, GetFiles()und zu verwenden GetDirectories().

gsharp
quelle
6
Was ist mit stackoverflow.com/questions/12415105/…? "Wenn Sie Directory.Delete aufrufen und eine Datei auf diese Weise geöffnet ist, kann Directory.Delete alle Dateien erfolgreich löschen. Wenn Directory.Delete RemoveDirectory aufruft, ist ein" Verzeichnis nicht leer ". Ausnahme wird ausgelöst, weil eine Datei zum Löschen markiert, aber nicht tatsächlich gelöscht ist. "
Kiquenet
74
DirectoryInfo ist langsam, da dadurch viel mehr andere Daten erfasst werden. Übrigens: Directory.Delete(path, true)wird sich um alles kümmern :)
AcidJunkie
57
@AcidJunkie, Dadurch wird auch das betreffende Verzeichnis entfernt, während das OP speziell die Beibehaltung des Stammverzeichnisses anfordert.
Marc L.
5
Beachten Sie, dass dies nicht funktioniert, wenn eine der Dateien schreibgeschützt ist. Sie müssen das schreibgeschützte Flag entfernen, bevor Sie anrufen file.Delete().
Ben
8
Dies scheint nicht zu funktionieren, wenn Unterverzeichnisse Dateien enthalten.
Cdiggins
174

Ja, das ist der richtige Weg. Wenn Sie sich eine "Clean" -Funktion (oder, wie ich es lieber nennen möchte, "Empty" -Funktion) geben möchten, können Sie eine Erweiterungsmethode erstellen.

public static void Empty(this System.IO.DirectoryInfo directory)
{
    foreach(System.IO.FileInfo file in directory.GetFiles()) file.Delete();
    foreach(System.IO.DirectoryInfo subDirectory in directory.GetDirectories()) subDirectory.Delete(true);
}

Auf diese Weise können Sie so etwas wie ... tun.

System.IO.DirectoryInfo directory = new System.IO.DirectoryInfo(@"C:\...");

directory.Empty();
Adam Robinson
quelle
4
Die letzte Zeile sollte subDirectory.Delete (true) anstelle von directory.Delete (true) sein. Ich habe gerade den Code ausgeschnitten und eingefügt und er hat das Hauptverzeichnis selbst gelöscht. Danke für den Code, es ist großartig!
Aximili
26
Beachten Sie, dass bereits Emptyin C # vorhanden ist, z string. Wenn ich etwas anderes mit dem Namen sehen Emptywürde, wäre ich überrascht, wenn es das Objekt (oder das Dateisystem) modifizieren würde, anstatt mir ein zu geben bool, das besagt, ob es leer ist oder nicht. Aus diesem Grund würde ich mit dem Namen gehen Clean.
Standard
5
@Default: Ich denke nicht, dass die Tatsache, dass ein Typ bereits eine Eigenschaft hat, einen Einfluss darauf haben sollte, ob ein anderer (völlig unabhängiger) Typ diese haben sollte. und die Konvention für Eigenschaften und Funktionen, die den Zustand von Wörtern angeben, die auch Verben sein können, besteht darin, ihnen Is(dh IsEmptynicht Empty) ein Präfix voranzustellen .
Adam Robinson
3
@ AdamRobinson Ich wollte es nur notieren. Für mich hat das , was Microsoft in seinem Code hat, eine gewisse Bedeutung. Aber es ist für jeden zu interpretieren :)
Standard
4
@simonhaines: Der Punkt der Frage war, das Verzeichnis zu leeren (dh alles darin zu löschen), nicht das Verzeichnis selbst zu löschen.
Adam Robinson
77

Der folgende Code löscht den Ordner rekursiv:

private void clearFolder(string FolderName)
{
    DirectoryInfo dir = new DirectoryInfo(FolderName);

    foreach(FileInfo fi in dir.GetFiles())
    {
        fi.Delete();
    }

    foreach (DirectoryInfo di in dir.GetDirectories())
    {
        clearFolder(di.FullName);
        di.Delete();
    }
}
hiteshbiblog
quelle
Arbeitete für mich, während Directory.Delete (Pfad, wahr); warf sich zu beschweren, dass der Ordner nicht empy war
Jack Griffin
40
 new System.IO.DirectoryInfo(@"C:\Temp").Delete(true);

 //Or

 System.IO.Directory.Delete(@"C:\Temp", true);
Thulasiram
quelle
1
Die zweite Option, Directory.Delete (String, Boolean), hat bei mir funktioniert.
Stephen MacDougall
15
Dadurch wird das Stammverzeichnis gelöscht, in dem das OP ausdrücklich darum gebeten hat, dass es beibehalten wird.
Marc L.
2
Deletewird geworfen, wenn das Verzeichnis nicht existiert, daher wäre es sicherer, zuerst eine Directory.ExistsÜberprüfung durchzuführen.
James
1
@ James Directory.Existsist nicht genug; Nach der Überprüfung hat möglicherweise ein anderer Thread das Verzeichnis umbenannt oder entfernt. Es ist sicherer zu try-catch.
andre_ss6
2
@ Marv Vorsicht beim einfachen Hinzufügen eines, Directory.Createda die Rekursion Directory.Deleteleider nicht garantiert synchron ist ..
Andrew Hanlon
38

Wir können auch Liebe für LINQ zeigen :

using System.IO;
using System.Linq;

var directory = Directory.GetParent(TestContext.TestDir);

directory.EnumerateFiles()
    .ToList().ForEach(f => f.Delete());

directory.EnumerateDirectories()
    .ToList().ForEach(d => d.Delete(true));

Beachten Sie, dass meine Lösung hier nicht performant ist, da ich sie verwende Get*().ToList().ForEach(...), die dieselbe IEnumerablezweimal generiert . Ich verwende eine Erweiterungsmethode, um dieses Problem zu vermeiden:

using System.IO;
using System.Linq;

var directory = Directory.GetParent(TestContext.TestDir);

directory.EnumerateFiles()
    .ForEachInEnumerable(f => f.Delete());

directory.EnumerateDirectories()
    .ForEachInEnumerable(d => d.Delete(true));

Dies ist die Erweiterungsmethode:

/// <summary>
/// Extensions for <see cref="System.Collections.Generic.IEnumerable"/>.
/// </summary>
public static class IEnumerableOfTExtensions
{
    /// <summary>
    /// Performs the <see cref="System.Action"/>
    /// on each item in the enumerable object.
    /// </summary>
    /// <typeparam name="TEnumerable">The type of the enumerable.</typeparam>
    /// <param name="enumerable">The enumerable.</param>
    /// <param name="action">The action.</param>
    /// <remarks>
    /// “I am philosophically opposed to providing such a method, for two reasons.
    /// …The first reason is that doing so violates the functional programming principles
    /// that all the other sequence operators are based upon. Clearly the sole purpose of a call
    /// to this method is to cause side effects.”
    /// —Eric Lippert, “foreach” vs “ForEach” [http://blogs.msdn.com/b/ericlippert/archive/2009/05/18/foreach-vs-foreach.aspx]
    /// </remarks>
    public static void ForEachInEnumerable<TEnumerable>(this IEnumerable<TEnumerable> enumerable, Action<TEnumerable> action)
    {
        foreach (var item in enumerable)
        {
            action(item);
        }
    }
}
rasx
quelle
1
Und wenn Sie auch versuchen, Unterverzeichnisse zu löschen, kann dies foreach (var dir in info.GetDirectories("*", SearchOption.AllDirectories).OrderByDescending(dir => dir.FullName.Length)) dir.Delete();hilfreich sein.
Warty
1
Wenn Sie Leistung mögen, sollten Sie directory.EnumerateFiles()und directory.EnumerateDirectories()anstelle der directory.Get*()Methoden verwenden.
Tinister
1
Komisch, meine eigene IEnumerable<T>.ForEach()Erweiterung hat einen zusammenfassenden XML-Kommentar: "Verletzung! Verletzung! Unrein!".
Marc L.
Hey, was ist der 2. Grund? Der 3.? Usw.?
Bill Roberts
lol @RASX - er spricht mit Ihnen: "Wenn Sie diesen philosophischen Einwänden nicht zustimmen und in diesem Muster einen praktischen Wert finden, schreiben Sie diesen trivialen Einzeiler auf jeden Fall selbst."
Bill Roberts
37

Der einfachste Weg:

Directory.Delete(path,true);  
Directory.CreateDirectory(path);

Beachten Sie, dass dadurch möglicherweise einige Berechtigungen für den Ordner gelöscht werden.

Igor Mukhachev
quelle
9
Beachten Sie, dass dadurch alle Sonderberechtigungen für den Pfad entfernt werden
Matthew Lock
6
Sie müssen eine Zeitüberschreitung zwischen diesen beiden Aktionen hinzufügen. Wenn Sie versuchen, diesen Code auszuführen, wird eine Ausnahme angezeigt: while (true) {Directory.Delete (@ "C: \ Myfolder", true); Directory.CreateDirectory (@ "C: \ Myfolder"); }
RcMan
31
private void ClearFolder(string FolderName)
{
    DirectoryInfo dir = new DirectoryInfo(FolderName);

    foreach(FileInfo fi in dir.GetFiles())
    {
        try
        {
            fi.Delete();
        }
        catch(Exception) { } // Ignore all exceptions
    }

    foreach(DirectoryInfo di in dir.GetDirectories())
    {
        ClearFolder(di.FullName);
        try
        {
            di.Delete();
        }
        catch(Exception) { } // Ignore all exceptions
    }
}

Wenn Sie wissen, dass es keine Unterordner gibt, ist so etwas möglicherweise am einfachsten:

    Directory.GetFiles(folderName).ForEach(File.Delete)
zumalifeguard
quelle
Ich habe diese Funktion verwendet, um den temporären Systemordner zu löschen. Ich habe gerade try-catch um Delete () und IsReadOnly hinzugefügt, um alle Ausnahmen zu ignorieren, und es hat funktioniert.
Humbads
@humbads, können Sie diese Antwort aktualisieren oder den Code hier einfügen, und ich werde mit Ihren Änderungen aktualisieren?
Zumalifeguard
13
System.IO.Directory.Delete(installPath, true);
System.IO.Directory.CreateDirectory(installPath);
MacGyver
quelle
3
Wie oben: Beachten Sie, dass dadurch alle Sonderberechtigungen für den Pfad entfernt werden.
hB0
8

Bei jeder Methode, die ich ausprobiert habe, sind sie irgendwann mit System.IO-Fehlern fehlgeschlagen. Die folgende Methode funktioniert mit Sicherheit, auch wenn der Ordner leer ist oder nicht, schreibgeschützt oder nicht usw.

ProcessStartInfo Info = new ProcessStartInfo();  
Info.Arguments = "/C rd /s /q \"C:\\MyFolder"";  
Info.WindowStyle = ProcessWindowStyle.Hidden;  
Info.CreateNoWindow = true;  
Info.FileName = "cmd.exe";  
Process.Start(Info); 
Alexandru Dicu
quelle
1
Ich bevorzuge immer rd / s / q + mkdir, wenn es darum geht, Verzeichnisse zu leeren.
Dawid Ohia
7
Dies ist keine plattformübergreifende Lösung. Unix-ähnliche Systeme haben eindeutig keine cmd.exe, sie führen nicht einmal EXE-Dateien aus. C # ist nicht nur Windows, sondern auch Mono, das plattformübergreifend ist.
Anzeigename
1
@SargeBorsch Es gab keine plattformübergreifende Anforderung in der Frage und da C # ist, wird die Lösung höchstwahrscheinlich für Windows verwendet. Es scheint die einzige Antwort zu sein, die keine .NET-Funktionen verwendet, daher ist es als Alternative ziemlich wertvoll.
Alex Pandrea
7

Hier ist das Tool, mit dem ich nach dem Lesen aller Beiträge geendet habe. Es tut

  • Löscht alles, was gelöscht werden kann
  • Gibt false zurück, wenn einige Dateien im Ordner verbleiben

Es behandelt

  • Schreibgeschützte Dateien
  • Löschverzögerung
  • Gesperrte Dateien

Directory.Delete wird nicht verwendet, da der Prozess ausnahmsweise abgebrochen wird.

    /// <summary>
    /// Attempt to empty the folder. Return false if it fails (locked files...).
    /// </summary>
    /// <param name="pathName"></param>
    /// <returns>true on success</returns>
    public static bool EmptyFolder(string pathName)
    {
        bool errors = false;
        DirectoryInfo dir = new DirectoryInfo(pathName);

        foreach (FileInfo fi in dir.EnumerateFiles())
        {
            try
            {
                fi.IsReadOnly = false;
                fi.Delete();

                //Wait for the item to disapear (avoid 'dir not empty' error).
                while (fi.Exists)
                {
                    System.Threading.Thread.Sleep(10);
                    fi.Refresh();
                }
            }
            catch (IOException e)
            {
                Debug.WriteLine(e.Message);
                errors = true;
            }
        }

        foreach (DirectoryInfo di in dir.EnumerateDirectories())
        {
            try
            {
                EmptyFolder(di.FullName);
                di.Delete();

                //Wait for the item to disapear (avoid 'dir not empty' error).
                while (di.Exists)
                {
                    System.Threading.Thread.Sleep(10);
                    di.Refresh();
                }
            }
            catch (IOException e)
            {
                Debug.WriteLine(e.Message);
                errors = true;
            }
        }

        return !errors;
    }
Eric Bole-Feysot
quelle
6

Der folgende Code bereinigt das Verzeichnis, lässt jedoch das Stammverzeichnis dort (rekursiv).

Action<string> DelPath = null;
DelPath = p =>
{
    Directory.EnumerateFiles(p).ToList().ForEach(File.Delete);
    Directory.EnumerateDirectories(p).ToList().ForEach(DelPath);
    Directory.EnumerateDirectories(p).ToList().ForEach(Directory.Delete);
};
DelPath(path);
hofi
quelle
6

ich benutzte

Directory.GetFiles(picturePath).ToList().ForEach(File.Delete);

Zum Löschen des alten Bildes brauche ich kein Objekt in diesem Ordner

Mohammad Farahani
quelle
1
Ich bin mir nicht sicher, ob du die .ToList ()
Ben Power
5

Die Verwendung nur statischer Methoden mit Datei und Verzeichnis anstelle von DateiInfo und VerzeichnisInfo ist schneller. (Siehe akzeptierte Antwort unter Was ist der Unterschied zwischen File und FileInfo in C #? ). Antwort als Dienstprogrammmethode angezeigt.

public static void Empty(string directory)
{
    foreach(string fileToDelete in System.IO.Directory.GetFiles(directory))
    {
        System.IO.File.Delete(fileToDelete);
    }
    foreach(string subDirectoryToDeleteToDelete in System.IO.Directory.GetDirectories(directory))
    {
        System.IO.Directory.Delete(subDirectoryToDeleteToDelete, true);
    }
}
Kriil
quelle
5
private void ClearFolder(string FolderName)
{
    DirectoryInfo dir = new DirectoryInfo(FolderName);

    foreach (FileInfo fi in dir.GetFiles())
    {
        fi.IsReadOnly = false;
        fi.Delete();
    }

    foreach (DirectoryInfo di in dir.GetDirectories())
    {
        ClearFolder(di.FullName);
        di.Delete();
    }
}
Mong Zhu
quelle
3
string directoryPath = "C:\Temp";
Directory.GetFiles(directoryPath).ToList().ForEach(File.Delete);
Directory.GetDirectories(directoryPath).ToList().ForEach(Directory.Delete);
A VH
quelle
Eine Ausnahme vom Typ 'System.IO.IOException' ist in mscorlib.dll aufgetreten, wurde jedoch im Benutzercode nicht behandelt. Zusätzliche Informationen: Das Verzeichnis ist nicht leer.
Kipusoep
3

Wenn Sie es in Windows 7 gerade manuell mit Windows Explorer erstellt haben, ähnelt die Verzeichnisstruktur der folgenden:

C:
  \AAA
    \BBB
      \CCC
        \DDD

Führen Sie den in der ursprünglichen Frage vorgeschlagenen Code aus, um das Verzeichnis C: \ AAA, die Zeile, zu bereinigen di.Delete(true)Wenn Sie schlägt beim Versuch, BBB zu löschen immer mit der IOException "Das Verzeichnis ist nicht leer" fehl. Dies liegt wahrscheinlich an Verzögerungen / Caching im Windows Explorer.

Der folgende Code funktioniert für mich zuverlässig:

static void Main(string[] args)
{
    DirectoryInfo di = new DirectoryInfo(@"c:\aaa");
    CleanDirectory(di);
}

private static void CleanDirectory(DirectoryInfo di)
{
    if (di == null)
        return;

    foreach (FileSystemInfo fsEntry in di.GetFileSystemInfos())
    {
        CleanDirectory(fsEntry as DirectoryInfo);
        fsEntry.Delete();
    }
    WaitForDirectoryToBecomeEmpty(di);
}

private static void WaitForDirectoryToBecomeEmpty(DirectoryInfo di)
{
    for (int i = 0; i < 5; i++)
    {
        if (di.GetFileSystemInfos().Length == 0)
            return;
        Console.WriteLine(di.FullName + i);
        Thread.Sleep(50 * i);
    }
}
Fernost
quelle
Was ist mit stackoverflow.com/questions/12415105/…? "Wenn Sie Directory.Delete aufrufen und eine Datei auf diese Weise geöffnet ist, kann Directory.Delete alle Dateien erfolgreich löschen. Wenn Directory.Delete RemoveDirectory aufruft, ist ein" Verzeichnis nicht leer ". Ausnahme wird ausgelöst, weil eine Datei zum Löschen markiert, aber nicht tatsächlich gelöscht ist. "
Kiquenet
@Kiquenet: Anscheinend haben wir ein Problem in Windows gefunden. Windows hätte die Liste der zum Löschen markierten Dateien konsultieren können. Wenn alle Dateien im Verzeichnis zum Löschen markiert sind, sagen Sie nicht, dass das Verzeichnis nicht leer ist. Auf jeden Fall ist mein WaitForDirectoryToBecomeEmpty () eine Problemumgehung.
Farfareast
2

Diese Version verwendet keine rekursiven Aufrufe und löst das schreibgeschützte Problem.

public static void EmptyDirectory(string directory)
{
    // First delete all the files, making sure they are not readonly
    var stackA = new Stack<DirectoryInfo>();
    stackA.Push(new DirectoryInfo(directory));

    var stackB = new Stack<DirectoryInfo>();
    while (stackA.Any())
    {
        var dir = stackA.Pop();
        foreach (var file in dir.GetFiles())
        {
            file.IsReadOnly = false;
            file.Delete();
        }
        foreach (var subDir in dir.GetDirectories())
        {
            stackA.Push(subDir);
            stackB.Push(subDir);
        }
    }

    // Then delete the sub directories depth first
    while (stackB.Any())
    {
        stackB.Pop().Delete();
    }
}
Jeppe Andreasen
quelle
1

Verwenden Sie die GetDirectories-Methode von DirectoryInfo.

foreach (DirectoryInfo subDir in new DirectoryInfo(targetDir).GetDirectories())
                    subDir.Delete(true);
Mr_Hmp
quelle
1

Das folgende Beispiel zeigt, wie Sie das tun können. Es erstellt zuerst einige Verzeichnisse und eine Datei und entfernt sie dann über Directory.Delete(topPath, true);:

    static void Main(string[] args)
    {
        string topPath = @"C:\NewDirectory";
        string subPath = @"C:\NewDirectory\NewSubDirectory";

        try
        {
            Directory.CreateDirectory(subPath);

            using (StreamWriter writer = File.CreateText(subPath + @"\example.txt"))
            {
                writer.WriteLine("content added");
            }

            Directory.Delete(topPath, true);

            bool directoryExists = Directory.Exists(topPath);

            Console.WriteLine("top-level directory exists: " + directoryExists);
        }
        catch (Exception e)
        {
            Console.WriteLine("The process failed: {0}", e.Message);
        }
    }

Es stammt von https://msdn.microsoft.com/en-us/library/fxeahc5f(v=vs.110).aspx .

Salma Tofaily
quelle
1

Es ist nicht der beste Weg, um mit dem oben genannten Problem umzugehen. Aber es ist eine Alternative ...

while (Directory.GetDirectories(dirpath).Length > 0)
 {
       //Delete all files in directory
       while (Directory.GetFiles(Directory.GetDirectories(dirpath)[0]).Length > 0)
       {
            File.Delete(Directory.GetFiles(dirpath)[0]);
       }
       Directory.Delete(Directory.GetDirectories(dirpath)[0]);
 }
dsmyrnaios
quelle
0
DirectoryInfo Folder = new DirectoryInfo(Server.MapPath(path)); 
if (Folder .Exists)
{
    foreach (FileInfo fl in Folder .GetFiles())
    {
        fl.Delete();
    }

    Folder .Delete();
}
Ashok Luhach
quelle
Könnten Sie genauer sein und erklären, wie und warum dies funktionieren sollte?
Tiefgefroren
3
Antworten mit nur Code sind nicht geeignet. Sie sollten erklären, wie und warum es funktionieren / das Problem lösen sollte.
Rdurand
0

Dies zeigt, wie wir den Ordner löschen und überprüfen, ob wir das Textfeld verwenden

using System.IO;
namespace delete_the_folder
{
public partial class Form1 : Form
{
    public Form1()
    {
        InitializeComponent();
    }

    private void Deletebt_Click(object sender, EventArgs e)
    {
        //the  first you should write the folder place
        if (Pathfolder.Text=="")
        {
            MessageBox.Show("ples write the path of the folder");
            Pathfolder.Select();
            //return;
        }

        FileAttributes attr = File.GetAttributes(@Pathfolder.Text);

        if (attr.HasFlag(FileAttributes.Directory))
            MessageBox.Show("Its a directory");
        else
            MessageBox.Show("Its a file");

        string path = Pathfolder.Text;
        FileInfo myfileinf = new FileInfo(path);
        myfileinf.Delete();

    }


}

}
Abdelrhman Khalil
quelle
0
using System.IO;

string[] filePaths = Directory.GetFiles(@"c:\MyDir\");

foreach (string filePath in filePaths)

File.Delete(filePath);
SynsMasTer
quelle
0

Anruf von der Hauptleitung

static void Main(string[] args)
{ 
   string Filepathe =<Your path>
   DeleteDirectory(System.IO.Directory.GetParent(Filepathe).FullName);              
}

Fügen Sie diese Methode hinzu

public static void DeleteDirectory(string path)
{
    if (Directory.Exists(path))
    {
        //Delete all files from the Directory
        foreach (string file in Directory.GetFiles(path))
        {
            File.Delete(file);
        }
        //Delete all child Directories
        foreach (string directory in Directory.GetDirectories(path))
        {
             DeleteDirectory(directory);
        }
        //Delete a Directory
        Directory.Delete(path);
    }
 }
Sansalk
quelle
0
 foreach (string file in System.IO.Directory.GetFiles(path))
 {
    System.IO.File.Delete(file);
 }

 foreach (string subDirectory in System.IO.Directory.GetDirectories(path))
 {
     System.IO.Directory.Delete(subDirectory,true); 
 } 
Manish Y.
quelle
0

Um den Ordner zu löschen, ist dies Code mithilfe eines Textfelds und einer Schaltfläche using System.IO;:

private void Deletebt_Click(object sender, EventArgs e)
{
    System.IO.DirectoryInfo myDirInfo = new DirectoryInfo(@"" + delete.Text);

    foreach (FileInfo file in myDirInfo.GetFiles())
    {
       file.Delete();
    }
    foreach (DirectoryInfo dir in myDirInfo.GetDirectories())
    {
       dir.Delete(true);
    }
}
Abdelrhman Khalil
quelle
-2
private void ClearDirectory(string path)
{
    if (Directory.Exists(path))//if folder exists
    {
        Directory.Delete(path, true);//recursive delete (all subdirs, files)
    }
    Directory.CreateDirectory(path);//creates empty directory
}
dadziu
quelle
2
Siehe unten ... "Löschen und Neuerstellen" ist nicht dasselbe wie Beibehalten, alle ACL-Anpassungen gehen verloren.
Marc L.
Ich habe etwas sehr Ähnliches versucht, da ich mich nicht um ACL-Anpassungen gekümmert habe und auf Probleme mit dem Ordner gestoßen bin, der nachDirectory.CreateDirectory
JG in SD
-3

Das einzige , was Sie tun sollten , ist gesetzt optional recursive parameterzu True.

Directory.Delete("C:\MyDummyDirectory", True)

Dank .NET. :) :)

LysanderM
quelle
3
Dadurch wird auch das Verzeichnis selbst gelöscht.
Rajat
-4
IO.Directory.Delete(HttpContext.Current.Server.MapPath(path), True)

Mehr brauchst du nicht

Mustafa Odeh
quelle
2
Falsch ... dies löscht auch das Stammverzeichnis.
L-Four