File.Copy File.Copy File.Copy File.Copy Method

Definition

Kopiert eine vorhandene Datei in eine neue Datei.Copies an existing file to a new file.

Überlädt

Copy(String, String) Copy(String, String) Copy(String, String) Copy(String, String)

Kopiert eine vorhandene Datei in eine neue Datei.Copies an existing file to a new file. Das Überschreiben einer gleichnamigen Datei ist nicht zulässig.Overwriting a file of the same name is not allowed.

Copy(String, String, Boolean) Copy(String, String, Boolean) Copy(String, String, Boolean) Copy(String, String, Boolean)

Kopiert eine vorhandene Datei in eine neue Datei.Copies an existing file to a new file. Das Überschreiben einer gleichnamigen Datei ist zulässig.Overwriting a file of the same name is allowed.

Copy(String, String) Copy(String, String) Copy(String, String) Copy(String, String)

Kopiert eine vorhandene Datei in eine neue Datei.Copies an existing file to a new file. Das Überschreiben einer gleichnamigen Datei ist nicht zulässig.Overwriting a file of the same name is not allowed.

public:
 static void Copy(System::String ^ sourceFileName, System::String ^ destFileName);
public static void Copy (string sourceFileName, string destFileName);
static member Copy : string * string -> unit
Public Shared Sub Copy (sourceFileName As String, destFileName As String)

Parameter

sourceFileName
String String String String

Die zu kopierende Datei.The file to copy.

destFileName
String String String String

Der Name der Zieldatei.The name of the destination file. Dies darf kein Verzeichnis und keine vorhandene Datei sein.This cannot be a directory or an existing file.

Ausnahmen

Der Aufrufer verfügt nicht über die erforderliche Berechtigung.The caller does not have the required permission.

sourceFileName oder destFileName ist eine leere Zeichenfolge, enthält nur Leerzeichen oder enthält mindestens ein ungültiges Zeichen gemäß der Definition von InvalidPathChars.sourceFileName or destFileName is a zero-length string, contains only white space, or contains one or more invalid characters as defined by InvalidPathChars.

- oder --or- sourceFileName oder destFileName gibt ein Verzeichnis an.sourceFileName or destFileName specifies a directory.

sourceFileName oder destFileName ist null.sourceFileName or destFileName is null.

Der angegebene Pfad und/oder Dateiname überschreiten die vom System definierte maximale Länge.The specified path, file name, or both exceed the system-defined maximum length.

Der in sourceFileName oder destFileName angegebene Pfad ist ungültig (er befindet sich z. B. auf einem nicht zugeordneten Laufwerk).The path specified in sourceFileName or destFileName is invalid (for example, it is on an unmapped drive).

sourceFileName wurde nicht gefunden.sourceFileName was not found.

destFileName ist vorhanden.destFileName exists.

- oder --or- Ein E/A-Fehler ist aufgetreten.An I/O error has occurred.

sourceFileName oder destFileName weist ein ungültiges Format auf.sourceFileName or destFileName is in an invalid format.

Beispiele

Im folgenden Beispiel werden die Dateien in den Sicherungsordner c:\archives\2008 kopiert.The following example copies files to the C:\archives\2008 backup folder. Dabei werden die beiden über Ladungen Copy der-Methode wie folgt verwendet:It uses the two overloads of the Copy method as follows:

  • Zuerst wird die File.Copy(String, String) -Methoden Überladung verwendet, um Textdateien (. txt) zu kopieren.It first uses the File.Copy(String, String) method overload to copy text (.txt) files. Der Code zeigt, dass diese Überladung das Überschreiben von Dateien, die bereits kopiert wurden, nicht zulässt.The code demonstrates that this overload does not allow overwriting files that were already copied.

  • Anschließend wird die File.Copy(String, String, Boolean) -Methoden Überladung verwendet, um Bilder (JPG-Dateien) zu kopieren.It then uses the File.Copy(String, String, Boolean) method overload to copy pictures (.jpg files). Der Code veranschaulicht, dass diese Überladung das Überschreiben von Dateien zulässt, die bereits kopiert wurden.The code demonstrates that this overload does allow overwriting files that were already copied.

string sourceDir = @"c:\current";
string backupDir = @"c:\archives\2008";

try
{
    string[] picList = Directory.GetFiles(sourceDir, "*.jpg");
    string[] txtList = Directory.GetFiles(sourceDir, "*.txt");

    // Copy picture files.
    foreach (string f in picList)
    {
        // Remove path from the file name.
        string fName = f.Substring(sourceDir.Length + 1);

        // Use the Path.Combine method to safely append the file name to the path.
        // Will overwrite if the destination file already exists.
        File.Copy(Path.Combine(sourceDir, fName), Path.Combine(backupDir, fName), true);
    }

    // Copy text files.
    foreach (string f in txtList)
    {

        // Remove path from the file name.
        string fName = f.Substring(sourceDir.Length + 1);

        try
        {
            // Will not overwrite if the destination file already exists.
            File.Copy(Path.Combine(sourceDir, fName), Path.Combine(backupDir, fName));
        }

        // Catch exception if the file was already copied.
        catch (IOException copyError)
        {
            Console.WriteLine(copyError.Message);
        }
    }

    // Delete source files that were copied.
    foreach (string f in txtList)
    {
        File.Delete(f);
    }
    foreach (string f in picList)
    {
        File.Delete(f);
    }
}

catch (DirectoryNotFoundException dirNotFound)
{
    Console.WriteLine(dirNotFound.Message);
}

Dim sourceDir As String = "c:\current"
Dim backupDir As String = "c:\archives\2008"

Try
    Dim picList As String() = Directory.GetFiles(sourceDir, "*.jpg")
    Dim txtList As String() = Directory.GetFiles(sourceDir, "*.txt")

    ' Copy picture files.
    For Each f As String In picList
        'Remove path from the file name.
        Dim fName As String = f.Substring(sourceDir.Length + 1)

        ' Use the Path.Combine method to safely append the file name to the path.
        ' Will overwrite if the destination file already exists.
        File.Copy(Path.Combine(sourceDir, fName), Path.Combine(backupDir, fName), True)
    Next

    ' Copy text files.
    For Each f As String In txtList

        'Remove path from the file name.
        Dim fName As String = f.Substring(sourceDir.Length + 1)

        Try
            ' Will not overwrite if the destination file already exists.
            File.Copy(Path.Combine(sourceDir, fName), Path.Combine(backupDir, fName))

            ' Catch exception if the file was already copied.
        Catch copyError As IOException
            Console.WriteLine(copyError.Message)
        End Try
    Next

    For Each f As String In txtList
        File.Delete(f)
    Next

    For Each f As String In picList
        File.Delete(f)
    Next

Catch dirNotFound As DirectoryNotFoundException
    Console.WriteLine(dirNotFound.Message)
End Try

Hinweise

Diese Methode entspricht der Copy(String, String, Boolean) -Methoden Überladung, bei der der overwrite - falseParameter auf festgelegt ist.This method is equivalent to the Copy(String, String, Boolean) method overload with the overwrite parameter set to false.

Mit sourceFileName den destFileName Parametern und können relative oder absolute Pfadinformationen angegeben werden.The sourceFileName and destFileName parameters can specify relative or absolute path information. Relative Pfadinformationen werden als relativ zum aktuellen Arbeitsverzeichnis interpretiert.Relative path information is interpreted as relative to the current working directory. Informationen zum Abrufen des aktuellen Arbeitsverzeichnisses finden Sie Directory.GetCurrentDirectory unter der-Methode.To obtain the current working directory, see the Directory.GetCurrentDirectory method. Diese Methode unterstützt keine Platzhalter Zeichen in den Parametern.This method does not support wildcard characters in the parameters.

Die Attribute der ursprünglichen Datei werden in der kopierten Datei beibehalten.The attributes of the original file are retained in the copied file.

Sicherheit

FileIOPermission
zum Lesen von sourceFileName und Schreiben in destFileName.for reading from sourceFileName and writing to destFileName. Zugehörige Enumerationen Read:,WriteAssociated enumerations: Read, Write

Siehe auch

Copy(String, String, Boolean) Copy(String, String, Boolean) Copy(String, String, Boolean) Copy(String, String, Boolean)

Kopiert eine vorhandene Datei in eine neue Datei.Copies an existing file to a new file. Das Überschreiben einer gleichnamigen Datei ist zulässig.Overwriting a file of the same name is allowed.

public:
 static void Copy(System::String ^ sourceFileName, System::String ^ destFileName, bool overwrite);
public static void Copy (string sourceFileName, string destFileName, bool overwrite);
static member Copy : string * string * bool -> unit
Public Shared Sub Copy (sourceFileName As String, destFileName As String, overwrite As Boolean)

Parameter

sourceFileName
String String String String

Die zu kopierende Datei.The file to copy.

destFileName
String String String String

Der Name der Zieldatei.The name of the destination file. Dabei darf es sich nicht um ein Verzeichnis handeln.This cannot be a directory.

overwrite
Boolean Boolean Boolean Boolean

true, wenn die Zieldatei überschrieben werden kann, andernfalls false.true if the destination file can be overwritten; otherwise, false.

Ausnahmen

Der Aufrufer verfügt nicht über die erforderliche Berechtigung.The caller does not have the required permission.

- oder --or- destFileName ist schreibgeschützt.destFileName is read-only.

- oder --or- overwrite ist true, destFileName ist vorhanden und ausgeblendet, aber sourceFileName ist nicht ausgeblendet.overwrite is true, destFileName exists and is hidden, but sourceFileName is not hidden.

sourceFileName oder destFileName ist eine leere Zeichenfolge, enthält nur Leerzeichen oder enthält mindestens ein ungültiges Zeichen gemäß der Definition von InvalidPathChars.sourceFileName or destFileName is a zero-length string, contains only white space, or contains one or more invalid characters as defined by InvalidPathChars.

- oder --or- sourceFileName oder destFileName gibt ein Verzeichnis an.sourceFileName or destFileName specifies a directory.

sourceFileName oder destFileName ist null.sourceFileName or destFileName is null.

Der angegebene Pfad und/oder Dateiname überschreiten die vom System definierte maximale Länge.The specified path, file name, or both exceed the system-defined maximum length.

Der in sourceFileName oder destFileName angegebene Pfad ist ungültig (er befindet sich z. B. auf einem nicht zugeordneten Laufwerk).The path specified in sourceFileName or destFileName is invalid (for example, it is on an unmapped drive).

sourceFileName wurde nicht gefunden.sourceFileName was not found.

destFileName ist vorhanden und overwrite ist false.destFileName exists and overwrite is false.

- oder --or- Ein E/A-Fehler ist aufgetreten.An I/O error has occurred.

sourceFileName oder destFileName weist ein ungültiges Format auf.sourceFileName or destFileName is in an invalid format.

Beispiele

Im folgenden Beispiel werden die Dateien in den Sicherungsordner c:\archives\2008 kopiert.The following example copies files to the C:\archives\2008 backup folder. Dabei werden die beiden über Ladungen Copy der-Methode wie folgt verwendet:It uses the two overloads of the Copy method as follows:

  • Zuerst wird die File.Copy(String, String) -Methoden Überladung verwendet, um Textdateien (. txt) zu kopieren.It first uses the File.Copy(String, String) method overload to copy text (.txt) files. Der Code zeigt, dass diese Überladung das Überschreiben von Dateien, die bereits kopiert wurden, nicht zulässt.The code demonstrates that this overload does not allow overwriting files that were already copied.

Anschließend wird die File.Copy(String, String, Boolean) -Methoden Überladung verwendet, um Bilder (JPG-Dateien) zu kopieren.It then uses the File.Copy(String, String, Boolean) method overload to copy pictures (.jpg files). Der Code veranschaulicht, dass diese Überladung das Überschreiben von Dateien zulässt, die bereits kopiert wurden.The code demonstrates that this overload does allow overwriting files that were already copied.

string sourceDir = @"c:\current";
string backupDir = @"c:\archives\2008";

try
{
    string[] picList = Directory.GetFiles(sourceDir, "*.jpg");
    string[] txtList = Directory.GetFiles(sourceDir, "*.txt");

    // Copy picture files.
    foreach (string f in picList)
    {
        // Remove path from the file name.
        string fName = f.Substring(sourceDir.Length + 1);

        // Use the Path.Combine method to safely append the file name to the path.
        // Will overwrite if the destination file already exists.
        File.Copy(Path.Combine(sourceDir, fName), Path.Combine(backupDir, fName), true);
    }

    // Copy text files.
    foreach (string f in txtList)
    {

        // Remove path from the file name.
        string fName = f.Substring(sourceDir.Length + 1);

        try
        {
            // Will not overwrite if the destination file already exists.
            File.Copy(Path.Combine(sourceDir, fName), Path.Combine(backupDir, fName));
        }

        // Catch exception if the file was already copied.
        catch (IOException copyError)
        {
            Console.WriteLine(copyError.Message);
        }
    }

    // Delete source files that were copied.
    foreach (string f in txtList)
    {
        File.Delete(f);
    }
    foreach (string f in picList)
    {
        File.Delete(f);
    }
}

catch (DirectoryNotFoundException dirNotFound)
{
    Console.WriteLine(dirNotFound.Message);
}

Dim sourceDir As String = "c:\current"
Dim backupDir As String = "c:\archives\2008"

Try
    Dim picList As String() = Directory.GetFiles(sourceDir, "*.jpg")
    Dim txtList As String() = Directory.GetFiles(sourceDir, "*.txt")

    ' Copy picture files.
    For Each f As String In picList
        'Remove path from the file name.
        Dim fName As String = f.Substring(sourceDir.Length + 1)

        ' Use the Path.Combine method to safely append the file name to the path.
        ' Will overwrite if the destination file already exists.
        File.Copy(Path.Combine(sourceDir, fName), Path.Combine(backupDir, fName), True)
    Next

    ' Copy text files.
    For Each f As String In txtList

        'Remove path from the file name.
        Dim fName As String = f.Substring(sourceDir.Length + 1)

        Try
            ' Will not overwrite if the destination file already exists.
            File.Copy(Path.Combine(sourceDir, fName), Path.Combine(backupDir, fName))

            ' Catch exception if the file was already copied.
        Catch copyError As IOException
            Console.WriteLine(copyError.Message)
        End Try
    Next

    For Each f As String In txtList
        File.Delete(f)
    Next

    For Each f As String In picList
        File.Delete(f)
    Next

Catch dirNotFound As DirectoryNotFoundException
    Console.WriteLine(dirNotFound.Message)
End Try

Hinweise

Mit sourceFileName den destFileName Parametern und können relative oder absolute Pfadinformationen angegeben werden.The sourceFileName and destFileName parameters can specify relative or absolute path information. Relative Pfadinformationen werden als relativ zum aktuellen Arbeitsverzeichnis interpretiert.Relative path information is interpreted as relative to the current working directory. Diese Methode unterstützt keine Platzhalter Zeichen in den Parametern.This method does not support wildcard characters in the parameters.

Die Attribute der ursprünglichen Datei werden in der kopierten Datei beibehalten.The attributes of the original file are retained in the copied file.

Eine Liste der allgemeinen e/a-Aufgaben finden Sie unter Allgemeine e/a-Aufgaben.For a list of common I/O tasks, see Common I/O Tasks.

Sicherheit

FileIOPermission
zum Lesen von sourceFileName und Schreiben in destFileName.for reading from sourceFileName and writing to destFileName. Zugehörige Enumerationen Read:,WriteAssociated enumerations: Read, Write

Siehe auch

Gilt für: