Подтвердить что ты не робот

С# - Получить список файлов, за исключением скрытых

Directory.GetFiles() возвращает все файлы, даже те, которые отмечены как скрытые. Есть ли способ получить список файлов, который исключает скрытые файлы?

4b9b3361

Ответ 1

Это должно сработать для вас:

DirectoryInfo directory = new DirectoryInfo(@"C:\temp");
FileInfo[] files = directory.GetFiles();

var filtered = files.Where(f => !f.Attributes.HasFlag(FileAttributes.Hidden));

foreach (var f in filtered)
{
    Debug.WriteLine(f);
}

Ответ 2

// check whether a file is hidden
bool isHidden = ((File.GetAttributes(filePath) & FileAttributes.Hidden) == FileAttributes.Hidden);

Ответ 3

Используя .NET 4.0 и Directory.EnumerateDirectories, вы можете использовать эту конструкцию:

var hiddenFilesQuery = from file in Directory.EnumerateDirectories(@"c:\temp")
                       let info = new FileInfo(file)
                       where (info.Attributes & FileAttributes.Hidden) == 0
                       select file;

Это в основном то же самое, что и другой ответ, кроме Directory.EnumerateDirectories - немного более ленивый. Это не очень полезно, если вы все перечисляете.

(Здесь дается запрос a, но более readeable).

Ответ 4

, если использование используется:

var filtered = files.Select(f => f) .Where(f => (f.Attributes & FileAttributes.Hidden) == 0);

это не находит скрытый файл, поэтому вы можете использовать:

var filtered = files.Select(f => f) .Where(f => (f.Attributes & FileAttributes.Hidden) == FileAttributes.Hidden);

это только чтение скрытого файла

Ответ 5

Одна строка Код:

FileInfo[] tmpFiles = tempDir.GetFiles().Where(file => 
            (file.Attributes & FileAttributes.Hidden) == 0).ToArray();

Ответ 6

Если вы используете SearchOption.TopDirectoryOnly - тогда он относительно прост, однако - он становится намного сложнее, если вы хотите рекурсивно перечислить все файлы с помощью SearchOption.AllDirectories. Если вы можете GetFiles, а затем отфильтровывать только чтение, но, к сожалению, он не будет работать с каталогами, помеченными как скрытые. Файлы под этими папками также отображаются в списке, но они не скрыты в отличие от каталога.

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

Это, по крайней мере, для скрытой папки Tortoise svn.svn. Он содержит много папок, которые не скрыты, но .svn скрыто. Наконец, я написал функцию, которая выглядит так:

    SearchOption sopt = SearchOption.AllDirectories;
    List<String> listFiles = new List<string>();
    List<DirectoryInfo> dirs2scan = new List<DirectoryInfo>();

    dirs2scan.Add(new DirectoryInfo(fromPath) );

    for( ; dirs2scan.Count != 0; )
    {
        int scanIndex = dirs2scan.Count - 1;        // Try to preserve somehow alphabetic order which GetFiles returns 
                                                    // by scanning though last directory.
        FileInfo[] filesInfo = dirs2scan[scanIndex].GetFiles(pattern, SearchOption.TopDirectoryOnly);

        foreach (FileInfo fi in filesInfo)
        {
            if (bNoHidden && fi.Attributes.HasFlag(FileAttributes.Hidden))
                continue;

            listFiles.Add(fi.FullName);
        }

        if( sopt != SearchOption.AllDirectories )
            break;

        foreach (DirectoryInfo dir in dirs2scan[scanIndex].GetDirectories("*", SearchOption.TopDirectoryOnly))
        {
            if (bNoHidden && dir.Attributes.HasFlag(FileAttributes.Hidden))
                continue;

            dirs2scan.Add(dir);
        }
        dirs2scan.RemoveAt(scanIndex);
    }

sopt может использоваться параметр в функции, если необходимо или удаляется, если не требуется.

Ответ 7

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

private void SearchDirectory(DirectoryInfo startDirectory, 
                             string pattern, 
                             Action<FileInfo> act)
{
    foreach (var file in startDirectory.GetFiles(pattern))
        act(file);

    foreach (var directory in startDirectory.GetDirectories())
        SearchDirectory(directory, pattern, act);
}

private List<FileInfo> SearchDirectory(DirectoryInfo startDirectory, 
                                       string pattern, 
                                       Func<FileInfo, bool> isWanted)
{
    var lst = new List<FileInfo>();
    SearchDirectory(startDirectory, 
                    pattern, 
                    (fi) => { if (isWanted(fi)) lst.Add(fi); });
    return lst;
}

Затем вы можете использовать другие решения, перечисленные для записи функции IsHidden, которая принимает одну FileInfo и возвращает true, если это так:

private bool IsHiddenDirectory(DirectoryInfo d) {
    if (d == null) return false;
    if (d.Attributes.HasFlag(FileAttributes.Hidden))) return true;
    if (d.Parent == null) return false;
    return IsHiddenDirectory(d.Parent);
}

private bool IsHidden(FileInfo fi) {
    if ((fi.Attributes & FileAttributes.Hidden) != 0) return true;
    // If you're worried about parent directories hidden:
    return IsHiddenDirectory(fi.Directory);
    // otherwise:
    return false;
}

Тогда я могу назвать это другим способом довольно легко:

var files = SearchDirectory(new DirectoryInfo("C:\temp\"),
                            "*.xml",
                            (fi) => { return !IsHidden(fi); );