Directory.GetDirectories Метод

Определение

Возвращает имена подкаталогов, которые соответствуют указанным критериям.

Перегрузки

Имя Описание
GetDirectories(String, String, SearchOption)

Возвращает имена подкаталогов (включая их пути), соответствующие указанному шаблону поиска в указанном каталоге, и при необходимости выполняет поиск подкаталогов.

GetDirectories(String, String, EnumerationOptions)

Возвращает имена подкаталогов (включая их пути), которые соответствуют указанному шаблону поиска и параметрам перечисления в указанном каталоге.

GetDirectories(String, String)

Возвращает имена подкаталогов (включая их пути), которые соответствуют указанному шаблону поиска в указанном каталоге.

GetDirectories(String)

Возвращает имена подкаталогов (включая их пути) в указанном каталоге.

GetDirectories(String, String, SearchOption)

Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs

Возвращает имена подкаталогов (включая их пути), соответствующие указанному шаблону поиска в указанном каталоге, и при необходимости выполняет поиск подкаталогов.

public:
 static cli::array <System::String ^> ^ GetDirectories(System::String ^ path, System::String ^ searchPattern, System::IO::SearchOption searchOption);
public static string[] GetDirectories(string path, string searchPattern, System.IO.SearchOption searchOption);
static member GetDirectories : string * string * System.IO.SearchOption -> string[]
Public Shared Function GetDirectories (path As String, searchPattern As String, searchOption As SearchOption) As String()

Параметры

path
String

Относительный или абсолютный путь к каталогу для поиска. Эта строка не учитывает регистр.

searchPattern
String

Строка поиска, соответствующая именам подкаталогов.path Этот параметр может содержать сочетание допустимых литеральных и подстановочных знаков, но не поддерживает регулярные выражения.

searchOption
SearchOption

Одно из значений перечисления, указывающее, должна ли операция поиска включать все подкаталоги или только текущий каталог.

Возвращаемое значение

String[]

Массив полных имен (включая пути) подкаталогов, соответствующих указанным критериям, или пустой массив, если каталоги не найдены.

Исключения

Версии .NET Framework и .NET Core старше 2.1: path представляет собой строку нулевой длины, содержит только пробелы или содержит один или несколько недопустимых символов. Вы можете запросить недопустимые символы с помощью метода GetInvalidPathChars().

–или–

searchPattern не содержит допустимый шаблон.

path или searchPattern есть null.

searchOption недопустимое SearchOption значение.

Вызывающий объект не имеет требуемого разрешения.

Указанный путь, имя файла или оба превышают определенную системой максимальную длину.

path — это имя файла.

–или–

Файл или каталог поврежден и нечитаем (например, недопустимый первый блок выделения раздела FAT32).

Указанный путь недопустим (например, он находится на несопоставленном диске).

Примеры

В следующем примере число каталогов, начинающихся с указанного буквы, в пути. Выполняется поиск только каталога верхнего уровня.

using System;
using System.IO;

class Test
{
    public static void Main()
    {
        try
        {
            string[] dirs = Directory.GetDirectories(@"c:\", "p*", SearchOption.TopDirectoryOnly);
            Console.WriteLine("The number of directories starting with p is {0}.", dirs.Length);
            foreach (string dir in dirs)
            {
                Console.WriteLine(dir);
            }
        }
        catch (Exception e)
        {
            Console.WriteLine("The process failed: {0}", e.ToString());
        }
    }
}
open System.IO

try
    let dirs = Directory.GetDirectories(@"c:\", "p*", SearchOption.TopDirectoryOnly)
    printfn $"The number of directories starting with p is {dirs.Length}."
    for dir in dirs do
        printfn $"{dir}"
with e ->
    printfn $"The process failed: {e}"
Imports System.IO

Public Class Test
    Public Shared Sub Main()
        Try
            Dim dirs As String() = Directory.GetDirectories("c:\", "p*", SearchOption.TopDirectoryOnly)
            Console.WriteLine("The number of directories starting with p is {0}.", dirs.Length)
            Dim dir As String
            For Each dir In dirs
                Console.WriteLine(dir)
            Next
        Catch e As Exception
            Console.WriteLine("The process failed: {0}", e.ToString())
        End Try
    End Sub
End Class

Комментарии

Параметр path может указывать относительные или абсолютные сведения о пути и не учитывает регистр. Относительные сведения о пути интерпретируются как относительные к текущему рабочему каталогу. Чтобы получить текущий рабочий каталог, см. GetCurrentDirectory.

searchPattern может быть сочетанием символов литерала и подстановочных знаков, но не поддерживает регулярные выражения. Следующие описатели подстановочных знаков разрешены в searchPattern.

Описатель подстановочных знаков Совпадения
* (звездочка) Ноль или больше символов в этой позиции.
? (вопросительный знак) Ровно один символ в этой позиции.

Символы, отличные от подстановочного знака, являются литеральными символами. Например, searchPattern строка "*t" выполняет поиск всех имен в path конце буквы "t". Строка searchPattern "s*" выполняет поиск всех имен, path начиная с буквы "s".

searchPattern не может заканчиваться двумя периодами ("..") или содержать два периода (".).), за которыми следует DirectorySeparatorChar или AltDirectorySeparatorCharне может содержать недопустимые символы. Вы можете запросить недопустимые символы с помощью метода GetInvalidPathChars.

Методы EnumerateDirectories отличаются следующим образом: при использовании GetDirectoriesможно начать перечисление коллекции имен до возврата всей коллекции. При использовании EnumerateDirectoriesнеобходимо дождаться возврата всего массива имен, прежде чем получить доступ к массиву.GetDirectories Поэтому при работе с большим количеством файлов и каталогов EnumerateDirectories может быть более эффективным.

Список распространенных задач ввода-вывода см. в разделе Распространенные задачи ввода-вывода.

См. также раздел

Применяется к

GetDirectories(String, String, EnumerationOptions)

Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs

Возвращает имена подкаталогов (включая их пути), которые соответствуют указанному шаблону поиска и параметрам перечисления в указанном каталоге.

public:
 static cli::array <System::String ^> ^ GetDirectories(System::String ^ path, System::String ^ searchPattern, System::IO::EnumerationOptions ^ enumerationOptions);
public static string[] GetDirectories(string path, string searchPattern, System.IO.EnumerationOptions enumerationOptions);
static member GetDirectories : string * string * System.IO.EnumerationOptions -> string[]
Public Shared Function GetDirectories (path As String, searchPattern As String, enumerationOptions As EnumerationOptions) As String()

Параметры

path
String

Относительный или абсолютный путь к каталогу для поиска. Эта строка не учитывает регистр.

searchPattern
String

Строка поиска, соответствующая именам подкаталогов.path Этот параметр может содержать сочетание допустимых литеральных и подстановочных знаков, но не поддерживает регулярные выражения.

enumerationOptions
EnumerationOptions

Объект, описывающий конфигурацию поиска и перечисления для использования.

Возвращаемое значение

String[]

Массив полных имен (включая пути) подкаталогов, соответствующих шаблону поиска и параметрам перечисления в указанном каталоге, или пустой массив, если каталоги не найдены.

Исключения

Вызывающий объект не имеет требуемого разрешения.

Версии .NET Framework и .NET Core старше 2.1: path представляет собой строку нулевой длины, содержит только пробелы или содержит один или несколько недопустимых символов. Вы можете запросить недопустимые символы с помощью GetInvalidPathChars().

–или–

searchPattern не содержит допустимый шаблон.

path или searchPattern есть null.

Указанный путь, имя файла или оба превышают определенную системой максимальную длину.

path — это имя файла.

–или–

Файл или каталог поврежден и нечитаем (например, недопустимый первый блок выделения раздела FAT32).

Указанный путь недопустим (например, он находится на несопоставленном диске).

Комментарии

Этот метод возвращает все вложенные каталоги непосредственно в указанном каталоге, соответствующий указанному шаблону поиска. Если указанный каталог не имеет подкаталогов или подкаталогов не соответствует searchPattern параметру, этот метод возвращает пустой массив. Поиск выполняется только в верхнем каталоге. Если вы хотите выполнить поиск по подкаталогам, используйте GetDirectories(String, String, SearchOption) метод и укажите AllDirectories в параметре searchOption .

searchPattern может быть сочетанием символов литерала и подстановочных знаков, но не поддерживает регулярные выражения. Следующие описатели подстановочных знаков разрешены в searchPattern.

Описатель подстановочных знаков Совпадения
* (звездочка) Ноль или больше символов в этой позиции.
? (вопросительный знак) Ровно один символ в этой позиции.

Символы, отличные от подстановочного знака, являются литеральными символами. Например, searchPattern строка "*t" выполняет поиск всех имен в path конце буквы "t". Строка searchPattern "s*" выполняет поиск всех имен, path начиная с буквы "s".

searchPattern не может заканчиваться двумя периодами ("..") или содержать два периода (".).), за которыми следует DirectorySeparatorChar или AltDirectorySeparatorCharне может содержать недопустимые символы. Вы можете запросить недопустимые символы с помощью метода GetInvalidPathChars.

Параметр path может указывать относительные или абсолютные сведения о пути и не учитывает регистр. Относительные сведения о пути интерпретируются как относительные к текущему рабочему каталогу. Чтобы получить текущий рабочий каталог, см. GetCurrentDirectory.

Методы EnumerateDirectories отличаются следующим образом: при использовании GetDirectoriesможно начать перечисление коллекции имен до возврата всей коллекции. При использовании EnumerateDirectoriesнеобходимо дождаться возврата всего массива имен, прежде чем получить доступ к массиву.GetDirectories Поэтому при работе с большим количеством файлов и каталогов EnumerateDirectories может быть более эффективным.

Список распространенных задач ввода-вывода см. в разделе Распространенные задачи ввода-вывода.

Применяется к

GetDirectories(String, String)

Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs

Возвращает имена подкаталогов (включая их пути), которые соответствуют указанному шаблону поиска в указанном каталоге.

public:
 static cli::array <System::String ^> ^ GetDirectories(System::String ^ path, System::String ^ searchPattern);
public static string[] GetDirectories(string path, string searchPattern);
static member GetDirectories : string * string -> string[]
Public Shared Function GetDirectories (path As String, searchPattern As String) As String()

Параметры

path
String

Относительный или абсолютный путь к каталогу для поиска. Эта строка не учитывает регистр.

searchPattern
String

Строка поиска, соответствующая именам подкаталогов.path Этот параметр может содержать сочетание допустимых литеральных и подстановочных знаков, но не поддерживает регулярные выражения.

Возвращаемое значение

String[]

Массив полных имен (включая пути) подкаталогов, соответствующих шаблону поиска в указанном каталоге, или пустой массив, если каталоги не найдены.

Исключения

Вызывающий объект не имеет требуемого разрешения.

Версии .NET Framework и .NET Core старше 2.1: path представляет собой строку нулевой длины, содержит только пробелы или содержит один или несколько недопустимых символов. Вы можете запросить недопустимые символы с помощью GetInvalidPathChars().

–или–

searchPattern не содержит допустимый шаблон.

path или searchPattern есть null.

Указанный путь, имя файла или оба превышают определенную системой максимальную длину.

path — это имя файла.

–или–

Файл или каталог поврежден и нечитаем (например, недопустимый первый блок выделения раздела FAT32).

Указанный путь недопустим (например, он находится на несопоставленном диске).

Примеры

В следующем примере число каталогов в пути, начинающегося с указанной буквы.

using System;
using System.IO;

class Test
{
    public static void Main()
    {
        try
        {
            // Only get subdirectories that begin with the letter "p."
            string[] dirs = Directory.GetDirectories(@"c:\", "p*");
            Console.WriteLine("The number of directories starting with p is {0}.", dirs.Length);
            foreach (string dir in dirs)
            {
                Console.WriteLine(dir);
            }
        }
        catch (Exception e)
        {
            Console.WriteLine("The process failed: {0}", e.ToString());
        }
    }
}
open System.IO

try
    // Only get subdirectories that begin with the letter "p."
    let dirs = Directory.GetDirectories(@"c:\", "p*")
    printfn $"The number of directories starting with p is {dirs.Length}."
    for dir in dirs do
        printfn $"{dir}"
with e ->
    printfn $"The process failed: {e}"
Imports System.IO

Public Class Test
    Public Shared Sub Main()
        Try
            ' Only get subdirectories that begin with the letter "p."
            Dim dirs As String() = Directory.GetDirectories("c:\", "p*")
            Console.WriteLine("The number of directories starting with p is {0}.", dirs.Length)
            Dim dir As String
            For Each dir In dirs
                Console.WriteLine(dir)
            Next
        Catch e As Exception
            Console.WriteLine("The process failed: {0}", e.ToString())
        End Try
    End Sub
End Class

Комментарии

Этот метод возвращает все вложенные каталоги непосредственно в указанном каталоге, соответствующий указанному шаблону поиска. Если указанный каталог не имеет подкаталогов или подкаталогов не соответствует searchPattern параметру, этот метод возвращает пустой массив. Поиск выполняется только в верхнем каталоге. Если вы хотите выполнить поиск по подкаталогам, используйте GetDirectories(String, String, SearchOption) метод и укажите AllDirectories в параметре searchOption .

searchPattern может быть сочетанием символов литерала и подстановочных знаков, но не поддерживает регулярные выражения. Следующие описатели подстановочных знаков разрешены в searchPattern.

Описатель подстановочных знаков Совпадения
* (звездочка) Ноль или больше символов в этой позиции.
? (вопросительный знак) Ровно один символ в этой позиции.

Символы, отличные от подстановочного знака, являются литеральными символами. Например, searchPattern строка "*t" выполняет поиск всех имен в path конце буквы "t". Строка searchPattern "s*" выполняет поиск всех имен, path начиная с буквы "s".

searchPattern не может заканчиваться двумя периодами ("..") или содержать два периода (".).), за которыми следует DirectorySeparatorChar или AltDirectorySeparatorCharне может содержать недопустимые символы. Вы можете запросить недопустимые символы с помощью метода GetInvalidPathChars.

Параметр path может указывать относительные или абсолютные сведения о пути и не учитывает регистр. Относительные сведения о пути интерпретируются как относительные к текущему рабочему каталогу. Чтобы получить текущий рабочий каталог, см. GetCurrentDirectory.

Методы EnumerateDirectories отличаются следующим образом: при использовании GetDirectoriesможно начать перечисление коллекции имен до возврата всей коллекции. При использовании EnumerateDirectoriesнеобходимо дождаться возврата всего массива имен, прежде чем получить доступ к массиву.GetDirectories Поэтому при работе с большим количеством файлов и каталогов EnumerateDirectories может быть более эффективным.

Список распространенных задач ввода-вывода см. в разделе Распространенные задачи ввода-вывода.

См. также раздел

Применяется к

GetDirectories(String)

Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs
Исходный код:
Directory.cs

Возвращает имена подкаталогов (включая их пути) в указанном каталоге.

public:
 static cli::array <System::String ^> ^ GetDirectories(System::String ^ path);
public static string[] GetDirectories(string path);
static member GetDirectories : string -> string[]
Public Shared Function GetDirectories (path As String) As String()

Параметры

path
String

Относительный или абсолютный путь к каталогу для поиска. Эта строка не учитывает регистр.

Возвращаемое значение

String[]

Массив полных имен (включая пути) подкаталогов в указанном пути или пустой массив, если каталоги не найдены.

Исключения

Вызывающий объект не имеет требуемого разрешения.

Версии .NET Framework и .NET Core старше 2.1: path представляет собой строку нулевой длины, содержит только пробелы или содержит один или несколько недопустимых символов. Вы можете запросить недопустимые символы с помощью метода GetInvalidPathChars().

path равно null.

Указанный путь, имя файла или оба превышают определенную системой максимальную длину.

path — это имя файла.

–или–

Файл или каталог поврежден и нечитаем (например, недопустимый первый блок выделения раздела FAT32).

Указанный путь недопустим (например, он находится на несопоставленном диске).

Примеры

В следующем примере выполняется массив имен файлов или каталогов в командной строке, определяется тип имени и обрабатывается соответствующим образом.

// For Directory.GetFiles and Directory.GetDirectories
// 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);	
    }
}
module RecursiveFileProcessor

open System.IO

// Insert logic for processing found files here.
let processFile path =
    printfn $"Processed file '%s{path}'."

// Process all files in the directory passed in, recurse on any directories
// that are found, and process the files they contain.
let rec processDirectory targetDirectory =
    // Process the list of files found in the directory.
    let fileEntries = Directory.GetFiles targetDirectory
    for fileName in fileEntries do
        processFile fileName

    // Recurse into subdirectories of this directory.
    let subdirectoryEntries = Directory.GetDirectories targetDirectory
    for subdirectory in subdirectoryEntries do
        processDirectory subdirectory

[<EntryPoint>]
let main args =
    for path in args do
        if File.Exists path then
            // This path is a file
            processFile path
        elif Directory.Exists path then
            // This path is a directory
            processDirectory path
        else
            printfn $"{path} is not a valid file or directory."
    0
' For Directory.GetFiles and Directory.GetDirectories
' For File.Exists, Directory.Exists 

Imports System.IO
Imports System.Collections

Public Class RecursiveFileProcessor

    Public Overloads Shared Sub Main(ByVal args() As String)
        Dim path As String
        For Each path In args
            If File.Exists(path) Then
                ' This path is a file.
                ProcessFile(path)
            Else
                If Directory.Exists(path) Then
                    ' This path is a directory.
                    ProcessDirectory(path)
                Else
                    Console.WriteLine("{0} is not a valid file or directory.", path)
                End If
            End If
        Next path
    End Sub


    ' Process all files in the directory passed in, recurse on any directories 
    ' that are found, and process the files they contain.
    Public Shared Sub ProcessDirectory(ByVal targetDirectory As String)
        Dim fileEntries As String() = Directory.GetFiles(targetDirectory)
        ' Process the list of files found in the directory.
        Dim fileName As String
        For Each fileName In fileEntries
            ProcessFile(fileName)

        Next fileName
        Dim subdirectoryEntries As String() = Directory.GetDirectories(targetDirectory)
        ' Recurse into subdirectories of this directory.
        Dim subdirectory As String
        For Each subdirectory In subdirectoryEntries
            ProcessDirectory(subdirectory)
        Next subdirectory

    End Sub

    ' Insert logic for processing found files here.
    Public Shared Sub ProcessFile(ByVal path As String)
        Console.WriteLine("Processed file '{0}'.", path)
    End Sub
End Class

Комментарии

Этот метод идентичен GetDirectories(String, String) звездочку (*), указанную в качестве шаблона поиска, поэтому возвращает все подкаталоги. Если вам нужно выполнить поиск подкаталогов, используйте GetDirectories(String, String, SearchOption) этот метод, который позволяет указать поиск подкаталогов с параметром searchOption .

Методы EnumerateDirectories отличаются следующим образом: при использовании GetDirectoriesможно начать перечисление коллекции имен до возврата всей коллекции. При использовании EnumerateDirectoriesнеобходимо дождаться возврата всего массива имен, прежде чем получить доступ к массиву.GetDirectories Поэтому при работе с большим количеством файлов и каталогов EnumerateDirectories может быть более эффективным.

Параметр может указывать относительные или абсолютные path сведения о пути. Относительные сведения о пути интерпретируются как относительные к текущему рабочему каталогу. Чтобы получить текущий рабочий каталог, см. GetCurrentDirectory.

Имена, возвращаемые этим методом, префиксируются с указанными в pathкаталоге сведениями.

Конфиденциальность регистра path параметра соответствует файловой системе, в которой выполняется код. Например, это не учитывает регистр в NTFS (файловая система Windows по умолчанию) и учитывает регистр в файловых системах Linux.

Список распространенных задач ввода-вывода см. в разделе Распространенные задачи ввода-вывода.

См. также раздел

Применяется к