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

Definición

Copia un archivo existente en un archivo nuevo.Copies an existing file to a new file.

Sobrecargas

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

Copia un archivo existente en un archivo nuevo.Copies an existing file to a new file. No se permite sobrescribir un archivo del mismo nombre.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)

Copia un archivo existente en un archivo nuevo.Copies an existing file to a new file. Se permite sobrescribir un archivo del mismo nombre.Overwriting a file of the same name is allowed.

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

Copia un archivo existente en un archivo nuevo.Copies an existing file to a new file. No se permite sobrescribir un archivo del mismo nombre.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)

Parámetros

sourceFileName
String String String String

Archivo que se va a copiar.The file to copy.

destFileName
String String String String

Nombre del archivo de destino.The name of the destination file. No puede ser un directorio o un archivo existente.This cannot be a directory or an existing file.

Excepciones

El llamador no dispone del permiso requerido.The caller does not have the required permission.

sourceFileName o destFileName es una cadena de longitud cero que solo contiene espacios en blanco o uno o varios caracteres no válidos definidos por InvalidPathChars.sourceFileName or destFileName is a zero-length string, contains only white space, or contains one or more invalid characters as defined by InvalidPathChars.

o bien-or- sourceFileName o destFileName especifica un directorio.sourceFileName or destFileName specifies a directory.

sourceFileName o destFileName es null.sourceFileName or destFileName is null.

La ruta de acceso especificada, el nombre de archivo o ambos superan la longitud máxima definida por el sistema.The specified path, file name, or both exceed the system-defined maximum length.

La ruta de acceso especificada en sourceFileName o destFileName no es válida (por ejemplo, está en una unidad no asignada).The path specified in sourceFileName or destFileName is invalid (for example, it is on an unmapped drive).

No se encontró sourceFileName.sourceFileName was not found.

destFileName existe.destFileName exists.

o bien-or- Se produjo un error de E/S.An I/O error has occurred.

sourceFileName o destFileName está en un formato no válido.sourceFileName or destFileName is in an invalid format.

Ejemplos

En el ejemplo siguiente se copian los archivos en la carpeta C:\archives\2008 backup.The following example copies files to the C:\archives\2008 backup folder. Utiliza las dos sobrecargas del método de Copy la siguiente manera:It uses the two overloads of the Copy method as follows:

  • En primer lugar, File.Copy(String, String) utiliza la sobrecarga del método para copiar los archivos de texto (. txt).It first uses the File.Copy(String, String) method overload to copy text (.txt) files. El código muestra que esta sobrecarga no permite sobrescribir archivos que ya se han copiado.The code demonstrates that this overload does not allow overwriting files that were already copied.

  • A continuación, usa File.Copy(String, String, Boolean) la sobrecarga del método para copiar imágenes (archivos. jpg).It then uses the File.Copy(String, String, Boolean) method overload to copy pictures (.jpg files). El código muestra que esta sobrecarga permite sobrescribir archivos que ya se han copiado.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

Comentarios

Este método es equivalente a la Copy(String, String, Boolean) sobrecarga del método con overwrite el parámetro establecido falseen.This method is equivalent to the Copy(String, String, Boolean) method overload with the overwrite parameter set to false.

Los sourceFileName parámetros destFileName y pueden especificar información de ruta de acceso relativa o absoluta.The sourceFileName and destFileName parameters can specify relative or absolute path information. La información de la ruta de acceso relativa se interpreta en relación con el directorio de trabajo actual.Relative path information is interpreted as relative to the current working directory. Para obtener el directorio de trabajo actual, vea Directory.GetCurrentDirectory el método.To obtain the current working directory, see the Directory.GetCurrentDirectory method. Este método no admite caracteres comodín en los parámetros.This method does not support wildcard characters in the parameters.

Los atributos del archivo original se conservan en el archivo copiado.The attributes of the original file are retained in the copied file.

Seguridad

FileIOPermission
para leer sourceFileName y escribir en destFileName.for reading from sourceFileName and writing to destFileName. Enumeraciones asociadas: Read,WriteAssociated enumerations: Read, Write

Consulte también:

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

Copia un archivo existente en un archivo nuevo.Copies an existing file to a new file. Se permite sobrescribir un archivo del mismo nombre.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)

Parámetros

sourceFileName
String String String String

Archivo que se va a copiar.The file to copy.

destFileName
String String String String

Nombre del archivo de destino.The name of the destination file. No puede ser un directorio.This cannot be a directory.

overwrite
Boolean Boolean Boolean Boolean

Es true si se puede sobrescribir el archivo de destino; en caso contrario, es false.true if the destination file can be overwritten; otherwise, false.

Excepciones

El llamador no dispone del permiso requerido.The caller does not have the required permission.

O bien-or- destFileName es de solo lectura.destFileName is read-only.

O bien-or- overwrite es true, destFileName existe y está oculto, pero sourceFileName no está oculto.overwrite is true, destFileName exists and is hidden, but sourceFileName is not hidden.

sourceFileName o destFileName es una cadena de longitud cero que solo contiene espacios en blanco o uno o varios caracteres no válidos definidos por InvalidPathChars.sourceFileName or destFileName is a zero-length string, contains only white space, or contains one or more invalid characters as defined by InvalidPathChars.

O bien-or- sourceFileName o destFileName especifica un directorio.sourceFileName or destFileName specifies a directory.

sourceFileName o destFileName es null.sourceFileName or destFileName is null.

La ruta de acceso especificada, el nombre de archivo o ambos superan la longitud máxima definida por el sistema.The specified path, file name, or both exceed the system-defined maximum length.

La ruta de acceso especificada en sourceFileName o destFileName no es válida (por ejemplo, está en una unidad no asignada).The path specified in sourceFileName or destFileName is invalid (for example, it is on an unmapped drive).

No se encontró sourceFileName.sourceFileName was not found.

destFileName existe y overwrite es false.destFileName exists and overwrite is false.

O bien-or- Se produjo un error de E/S.An I/O error has occurred.

sourceFileName o destFileName está en un formato no válido.sourceFileName or destFileName is in an invalid format.

Ejemplos

En el ejemplo siguiente se copian los archivos en la carpeta C:\archives\2008 backup.The following example copies files to the C:\archives\2008 backup folder. Utiliza las dos sobrecargas del método de Copy la siguiente manera:It uses the two overloads of the Copy method as follows:

  • En primer lugar, File.Copy(String, String) utiliza la sobrecarga del método para copiar los archivos de texto (. txt).It first uses the File.Copy(String, String) method overload to copy text (.txt) files. El código muestra que esta sobrecarga no permite sobrescribir archivos que ya se han copiado.The code demonstrates that this overload does not allow overwriting files that were already copied.

A continuación, usa File.Copy(String, String, Boolean) la sobrecarga del método para copiar imágenes (archivos. jpg).It then uses the File.Copy(String, String, Boolean) method overload to copy pictures (.jpg files). El código muestra que esta sobrecarga permite sobrescribir archivos que ya se han copiado.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

Comentarios

Los sourceFileName parámetros destFileName y pueden especificar información de ruta de acceso relativa o absoluta.The sourceFileName and destFileName parameters can specify relative or absolute path information. La información de la ruta de acceso relativa se interpreta en relación con el directorio de trabajo actual.Relative path information is interpreted as relative to the current working directory. Este método no admite caracteres comodín en los parámetros.This method does not support wildcard characters in the parameters.

Los atributos del archivo original se conservan en el archivo copiado.The attributes of the original file are retained in the copied file.

Para obtener una lista de tareas de e/s comunes, consulte tareas comunes de e/s.For a list of common I/O tasks, see Common I/O Tasks.

Seguridad

FileIOPermission
para leer sourceFileName y escribir en destFileName.for reading from sourceFileName and writing to destFileName. Enumeraciones asociadas: Read,WriteAssociated enumerations: Read, Write

Consulte también:

Se aplica a