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

Das folgende Beispiel kopiert die Dateien auf den Sicherungsordner C:\archives\2008.The following example copies files to the C:\archives\2008 backup folder. Er verwendet die zwei Überladungen der Copy -Methode wie folgt:It uses the two overloads of the Copy method as follows:

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

  • Anschließend wird mithilfe der File.Copy(String, String, Boolean) -methodenüberladung, um das Kopieren von Bildern (JPG-Dateien).It then uses the File.Copy(String, String, Boolean) method overload to copy pictures (.jpg files). Der Code zeigt, dass diese Überladung zulässt Überschreiben von Dateien, 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 mit dem overwrite Parametersatz zu false.This method is equivalent to the Copy(String, String, Boolean) method overload with the overwrite parameter set to false.

Die sourceFileName und destFileName Parameter relativer oder absoluter Pfad-Informationen angeben können.The sourceFileName and destFileName parameters can specify relative or absolute path information. Relativer Pfad wird relativ zum aktuellen Arbeitsverzeichnis interpretiert.Relative path information is interpreted as relative to the current working directory. Um das aktuelle Arbeitsverzeichnis zu erhalten, finden Sie unter den Directory.GetCurrentDirectory Methode.To obtain the current working directory, see the Directory.GetCurrentDirectory method. Diese Methode unterstützt die Platzhalterzeichen in den Parametern nicht.This method does not support wildcard characters in the parameters.

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

Sicherheit

FileIOPermission
für das Lesen von sourceFileName der und Schreiben in destFileName.for reading from sourceFileName and writing to destFileName. Zugeordnete 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

Das folgende Beispiel kopiert die Dateien auf den Sicherungsordner C:\archives\2008.The following example copies files to the C:\archives\2008 backup folder. Er verwendet die zwei Überladungen der Copy -Methode wie folgt:It uses the two overloads of the Copy method as follows:

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

Anschließend wird mithilfe der File.Copy(String, String, Boolean) -methodenüberladung, um das Kopieren von Bildern (JPG-Dateien).It then uses the File.Copy(String, String, Boolean) method overload to copy pictures (.jpg files). Der Code zeigt, dass diese Überladung zulässt Überschreiben von Dateien, 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

Die sourceFileName und destFileName Parameter relativer oder absoluter Pfad-Informationen angeben können.The sourceFileName and destFileName parameters can specify relative or absolute path information. Relativer Pfad wird relativ zum aktuellen Arbeitsverzeichnis interpretiert.Relative path information is interpreted as relative to the current working directory. Diese Methode unterstützt die Platzhalterzeichen in den Parametern nicht.This method does not support wildcard characters in the parameters.

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

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

Sicherheit

FileIOPermission
für das Lesen von sourceFileName der und Schreiben in destFileName.for reading from sourceFileName and writing to destFileName. Zugeordnete Enumerationen: Read, WriteAssociated enumerations: Read, Write

Siehe auch

Gilt für: