Leer en inglés

Compartir a través de


Directory.Exists(String) Método

Definición

Determina si la ruta de acceso dada hace referencia a un directorio existente en el disco.

C#
public static bool Exists (string path);
C#
public static bool Exists (string? path);

Parámetros

path
String

Ruta de acceso que se va a probar.

Devoluciones

true si path hace referencia a un directorio existente; false si el directorio no existe o se produce un error al intentar determinar si existe el directorio especificado.

Ejemplos

En el ejemplo siguiente se toma una matriz de nombres de archivo o directorio en la línea de comandos, se determina el tipo de nombre que es y se procesa correctamente.

C#
// For File.Exists, Directory.Exists
using System;
using System.IO;
using System.Collections;

public class RecursiveFileProcessor
{
    public static void Main(string[] args)
    {
        foreach(string path in args)
        {
            if(File.Exists(path))
            {
                // This path is a file
                ProcessFile(path);
            }
            else if(Directory.Exists(path))
            {
                // This path is a directory
                ProcessDirectory(path);
            }
            else
            {
                Console.WriteLine("{0} is not a valid file or directory.", path);
            }
        }
    }

    // Process all files in the directory passed in, recurse on any directories
    // that are found, and process the files they contain.
    public static void ProcessDirectory(string targetDirectory)
    {
        // Process the list of files found in the directory.
        string [] fileEntries = Directory.GetFiles(targetDirectory);
        foreach(string fileName in fileEntries)
            ProcessFile(fileName);

        // Recurse into subdirectories of this directory.
        string [] subdirectoryEntries = Directory.GetDirectories(targetDirectory);
        foreach(string subdirectory in subdirectoryEntries)
            ProcessDirectory(subdirectory);
    }

    // Insert logic for processing found files here.
    public static void ProcessFile(string path)
    {
        Console.WriteLine("Processed file '{0}'.", path);	
    }
}

Comentarios

El path parámetro puede especificar información de ruta de acceso relativa o absoluta. La información de ruta de acceso relativa se interpreta como relativa al directorio de trabajo actual.

Los espacios finales se quitan del final del path parámetro antes de comprobar si el directorio existe.

La distinción entre mayúsculas y minúsculas del path parámetro corresponde a la del sistema de archivos en el que se ejecuta el código. Por ejemplo, no distingue mayúsculas de minúsculas en NTFS (el sistema de archivos de Windows predeterminado) y distingue mayúsculas de minúsculas en sistemas de archivos Linux.

Si no tiene permiso mínimo de solo lectura para el directorio, el Exists método devolverá false.

El Exists método devuelve false si se produce algún error al intentar determinar si existe el archivo especificado. Esto puede producirse en situaciones en las que se produzcan excepciones como pasar un nombre de archivo con caracteres no válidos o demasiados caracteres, un disco con errores o que falten, o si el autor de la llamada no tiene permiso para leer el archivo.

Se aplica a

Producto Versiones
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Consulte también