Jak rekurencyjnie wyświetlić listę wszystkich plików w katalogu w C #?


315

Jak rekurencyjnie wyświetlić listę wszystkich plików w katalogu i katalogach potomnych w C #?


1
Gdzie chcesz zaludnić? jeśli drzewo ... oto przykład dreamincode.net/code/snippet2591.htm
Arsen Mkrtchyan

77
string [] filenames = Directory.GetFiles (ścieżka, „*”, SearchOption.AllDirectories)
Bruce

Możesz przyjrzeć się temu pytaniu, w którym przedstawiłem przykładowy kod, który używa rekurencji do renderowania struktury katalogów w TreeView. W większości przypadków logika powinna być taka sama.
Cerebrus

5
Problem polega na tym, że bardzo łatwo się psuje, jeśli nie masz dostępu do jednego katalogu: brak wyników ...
Marc Gravell

1
Jeśli napotkasz problemy, gdy niektóre pliki są niedostępne,
zapoznaj się z artykułem

Odpowiedzi:


186

Ten artykuł obejmuje wszystko, czego potrzebujesz. Oprócz przeszukiwania plików i porównywania nazw, wystarczy wydrukować nazwy.

Można go zmodyfikować w następujący sposób:

static void DirSearch(string sDir)
{
    try
    {
        foreach (string d in Directory.GetDirectories(sDir))
        {
            foreach (string f in Directory.GetFiles(d))
            {
                Console.WriteLine(f);
            }
            DirSearch(d);
        }
    }
    catch (System.Exception excpt)
    {
        Console.WriteLine(excpt.Message);
    }
}

Dodane przez barlop

GONeale wspomina, że ​​powyższe nie wyświetla plików w bieżącym katalogu i sugeruje umieszczenie części z listą plików poza częścią, która pobiera katalogi. Zrobiłyby to następujące. Zawiera również linię Writeline, którą można odkomentować, co pomaga śledzić, gdzie jesteś w rekurencji, co może pomóc w wyświetlaniu połączeń, aby pomóc pokazać, jak działa rekurencja.

            DirSearch_ex3("c:\\aaa");
            static void DirSearch_ex3(string sDir)
            {
                //Console.WriteLine("DirSearch..(" + sDir + ")");
                try
                {
                    Console.WriteLine(sDir);

                    foreach (string f in Directory.GetFiles(sDir))
                    {
                        Console.WriteLine(f);
                    }

                    foreach (string d in Directory.GetDirectories(sDir))
                    {
                        DirSearch_ex3(d);
                    }
                }
                catch (System.Exception excpt)
                {
                    Console.WriteLine(excpt.Message);
                }
            }

86
Ta metoda nie wyświetla plików dla katalogu początkowego, tylko jego podkatalogi i niższe. Przenosiłbym GetFiles poza
GetDirectories

1
Czasami nie chce się plików do katalogu początkowego, w którym to przypadku jest to idealne rozwiązanie dla stosunkowo małych struktur. W przypadku bardzo dużych list użyj czegoś takiego jak rozwiązanie Marca Gravella: stackoverflow.com/a/929418/91189
Joseph Gabriel

2
@GONeale jest poprawny. O wiele mniej prawdopodobne jest, że użytkownik nie spodziewa się listy plików wejściowego katalogu głównego. Tutaj wpisane słowo jest kluczowe. Został wprowadzony z jakiegoś powodu.
Florin Mircea,

2
Musiałem dodać próbny haczyk wokół wewnętrznej pętli foreach, w przeciwnym razie nie będzie to kontynuowało dostępu do odmowy dostępu
Shaun Vermaak

3
Powinieneś unikać łapania wyjątku - czy naprawdę chciałbyś na przykład złapać wyjątek OutOfMemoryException? Złap tylko to, co możesz obsłużyć.
alastairtree

435

Zauważ, że w .NET 4.0 wbudowane są (podobno) funkcje plików oparte na iteratorze (a nie tablice):

foreach (string file in Directory.EnumerateFiles(path, "*.*", SearchOption.AllDirectories))
{
    Console.WriteLine(file);
}

W tej chwili użyłbym czegoś takiego jak poniżej; wbudowana metoda rekurencyjna psuje się zbyt łatwo, jeśli nie masz dostępu do jednego podkatalogu ...; Queue<string>wykorzystanie pozwala uniknąć zbyt dużego stosu rekursji wezwanie, a blok iterator unika nas ma ogromną tablicę.

static void Main() {
    foreach (string file in GetFiles(SOME_PATH)) {
        Console.WriteLine(file);
    }
}

static IEnumerable<string> GetFiles(string path) {
    Queue<string> queue = new Queue<string>();
    queue.Enqueue(path);
    while (queue.Count > 0) {
        path = queue.Dequeue();
        try {
            foreach (string subDir in Directory.GetDirectories(path)) {
                queue.Enqueue(subDir);
            }
        }
        catch(Exception ex) {
            Console.Error.WriteLine(ex);
        }
        string[] files = null;
        try {
            files = Directory.GetFiles(path);
        }
        catch (Exception ex) {
            Console.Error.WriteLine(ex);
        }
        if (files != null) {
            for(int i = 0 ; i < files.Length ; i++) {
                yield return files[i];
            }
        }
    }
}

1
@soandos W punkcie rekurencyjnym powtarzalnym EnumerateFiles zgłasza wyjątek IOException „Nazwa pliku nie może zostać
rozpoznana

5
Dla wszystkich, którzy chcą wiedzieć, czy *.*zawiera również pliki bez rozszerzenia pliku: Tak, tak, przetestowano przed chwilą.
Tobias Knauss,

1
Aby tego użyć, musisz dodaćusing System.IO;
Przywróć Monikę - Do widzenia SE

7
@Wikis i do użycia Consolebędziesz musiał dodać using System;- ale ponieważ IDE może dodać dla ciebie wszystkie niezbędne usingdyrektywy (ctrl +.), A ponieważ nie używamy tutaj żadnych egzotycznych rzeczy, często ich nie dołączasz. Cholera, potrzebujesz także definicji itp. Po prostu mówięclass
Marc Gravell

1
@MarcGravell Jesteśmy teraz w świecie .net i świecie Visual Studio Code, dlatego też użycie instrukcji jest zawsze mile widziane w każdym przykładowym kodzie .net, aby zapisać serię wyszukiwań i bezcelowe „jak golenie”
JohnC

98
Directory.GetFiles("C:\\", "*.*", SearchOption.AllDirectories)

2
Jak uniknąć błędu, jeśli użytkownik logowania nie ma dostępu do niektórych folderów.
Romil Kumar Jain,

5
@Romil Nie wierzę, że ten fragment kodu próbuje wskazać pełną funkcjonalność, tylko surową funkcjonalność, której szukał OP. Dzięki za udostępnienie, Pescuma!
kayleeFrye_onDeck

@kayleeFrye_onDeck, zwracam tylko uwagę na wypadek podniesienia dowolnego folderu podczas pobierania plików. Z tego powodu wdrażamy naszą niestandardową funkcję rekurencyjną.
Romil Kumar Jain,

3
Dzięki temu rozwiązaniu otrzymasz „UnauthorizedAccessException”. Powinieneś mieć rozwiązanie, które poradzi sobie z takimi błędami.
Kairan

13

W wersji .NET 4.5 jest co najmniej ta wersja, która jest znacznie krótsza i ma dodatkową zaletę oceny dowolnych kryteriów plików do włączenia na listę:

public static IEnumerable<string> GetAllFiles(string path, 
                                              Func<FileInfo, bool> checkFile = null)
{
    string mask = Path.GetFileName(path);
    if (string.IsNullOrEmpty(mask)) mask = "*.*";
    path = Path.GetDirectoryName(path);
    string[] files = Directory.GetFiles(path, mask, SearchOption.AllDirectories);

    foreach (string file in files)
    {
        if (checkFile == null || checkFile(new FileInfo(file)))
            yield return file;
    }
}

Użyj w ten sposób:

var list = GetAllFiles(mask, (info) => Path.GetExtension(info.Name) == ".html").ToList();

To nie obsługuje przypadku, w którym masz pusty katalog ... wewnątrz funkcji nie ma instrukcji return.
FrumkinWY,

@FrumkinWY co dzieje się z pustym katalogiem? Nie mam teraz pod ręką maszyny, żeby to przetestować.
John Kaster,

12
IEnumerable<string> GetFilesFromDir(string dir) =>
 Directory.EnumerateFiles(dir).Concat(
 Directory.EnumerateDirectories(dir)
          .SelectMany(subdir => GetFilesFromDir(subdir)));

3

W Framework 2.0 możesz użyć (Lista plików w folderze głównym, najlepiej najpopularniejsza odpowiedź):

static void DirSearch(string dir)
{
    try
    {
        foreach (string f in Directory.GetFiles(dir))
            Console.WriteLine(f);
        foreach (string d in Directory.GetDirectories(dir))
        {
            Console.WriteLine(d);
            DirSearch(d);
        }

    }
    catch (System.Exception ex)
    {
        Console.WriteLine(ex.Message);
    }
}

3

Kilka doskonałych odpowiedzi, ale te odpowiedzi nie rozwiązały mojego problemu.

Gdy tylko pojawi się problem z uprawnieniami do folderu: „Odmowa zezwolenia”, kod nie działa. Właśnie tak omijałem problem „Odmowa zezwolenia”:

private int counter = 0;

    private string[] MyDirectories = Directory.GetDirectories("C:\\");

    private void ScanButton_Click(object sender, EventArgs e)
    {
        Thread MonitorSpeech = new Thread(() => ScanFiles());
        MonitorSpeech.Start();
    }

    private void ScanFiles()
    {
        string CurrentDirectory = string.Empty;

        while (counter < MyDirectories.Length)
        {
            try
            {
                GetDirectories();
                CurrentDirectory = MyDirectories[counter++];
            }
            catch
            {
                if (!this.IsDisposed)
                {
                    listBox1.Invoke((MethodInvoker)delegate { listBox1.Items.Add("Access Denied to : " + CurrentDirectory); });
                }
            }
        }
    }

    private void GetDirectories()
    {
        foreach (string directory in MyDirectories)
        {
            GetFiles(directory);
        }
    }

    private void GetFiles(string directory)
    {
        try
        {
            foreach (string file in Directory.GetFiles(directory, "*"))
            {
                listBox1.Invoke((MethodInvoker)delegate { listBox1.Items.Add(file); });
            }
        }
        catch
        {
            listBox1.Invoke((MethodInvoker)delegate { listBox1.Items.Add("Access Denied to : " + directory); });
        }
    }

Mam nadzieję, że to pomaga innym.


3

Proste i czyste rozwiązanie

/// <summary>
/// Scans a folder and all of its subfolders recursively, and updates the List of files
/// </summary>
/// <param name="sFullPath">Full path of the folder</param>
/// <param name="files">The list, where the output is expected</param>
internal static void EnumerateFiles(string sFullPath, List<FileInfo> fileInfoList)
{
    try
    {
        DirectoryInfo di = new DirectoryInfo(sFullPath);
        FileInfo[] files = di.GetFiles();

        foreach (FileInfo file in files)
            fileInfoList.Add(file);

        //Scan recursively
        DirectoryInfo[] dirs = di.GetDirectories();
        if (dirs == null || dirs.Length < 1)
            return;
        foreach (DirectoryInfo dir in dirs)
            EnumerateFiles(dir.FullName, fileInfoList);

    }
    catch (Exception ex)
    {
        Logger.Write("Exception in Helper.EnumerateFiles", ex);
    }
}

3
Robisz ręcznie to, co DirectoryInfo.GetFiles () zrobi dla Ciebie od razu po wyjęciu z pudełka - po prostu użyj przeciążenia za pomocą SearchOption.AllDirectories, a wszystko powtórzy się samo. To skomplikowane rozwiązanie.
philw

2

Wolę używać DirectoryInfo, ponieważ mogę uzyskać FileInfo, a nie tylko ciągi znaków.

        string baseFolder = @"C:\temp";
        DirectoryInfo di = new DirectoryInfo(baseFolder);

        string searchPattern = "*.xml";

        ICollection<FileInfo> matchingFileInfos = di.GetFiles(searchPattern, SearchOption.AllDirectories)
            .Select(x => x)
            .ToList();

Robię to na wypadek, gdyby w przyszłości potrzebowałem przyszłego filtrowania na podstawie właściwości FileInfo.

        string baseFolder = @"C:\temp";
        DirectoryInfo di = new DirectoryInfo(baseFolder);

        string searchPattern = "*.xml";

        ICollection<FileInfo> matchingFileInfos = di.GetFiles(searchPattern, SearchOption.AllDirectories)
            .Where(x => x.LastWriteTimeUtc < DateTimeOffset.Now)
            .Select(x => x)
            .ToList();

W razie potrzeby mogę również powrócić do ciągów znaków. (i nadal jestem gotowy na przyszłość w przypadku filtrów / klauzuli where-clause).

        string baseFolder = @"C:\temp";
        DirectoryInfo di = new DirectoryInfo(baseFolder);

        string searchPattern = "*.xml";

        ICollection<string> matchingFileNames = di.GetFiles(searchPattern, SearchOption.AllDirectories)
            .Select(x => x.FullName)
            .ToList();

Pamiętaj, że „ . ” Jest prawidłowym wzorcem wyszukiwania, jeśli chcesz filtrować według rozszerzenia.


1
private void GetFiles(DirectoryInfo dir, ref List<FileInfo> files)
{
    try
    {
        files.AddRange(dir.GetFiles());
        DirectoryInfo[] dirs = dir.GetDirectories();
        foreach (var d in dirs)
        {
            GetFiles(d, ref files);
        }
    }
    catch (Exception e)
    {

    }
}

1
Dlaczego ten parametr filesjest ref? Nie ma potrzeby.
Massimiliano Kraus,

@MassimilianoKraus Argumentowałbym, że chociaż nie jest to wymagane, to wyjaśnia, że ​​jego metoda ulegnie zmianie filesi nie możesz już podać new List<FileInfo>()jako parametru, co byłoby bezużyteczne. Może pozwolić na pewną suboptymalizację i uniknąć tworzenia nowego obiektu, chyba że jest to wymagane.
jeromej

@JeromeJ, jeśli wiesz, czym jest OOP, wiesz, że za każdym razem, gdy przekazujesz obiekt do metody, metoda ta może zmieniać właściwości / pola obiektu. Więc refnic nie wyjaśnia. ref„S celem jest zmienić cały fileswskaźnik nawet dla rozmówcy danej metody: jest to niebezpieczna operacja, a tu nie ma takiej potrzeby: można po prostu wypełnić listy, nie trzeba ponownie skierować go do innej listy na kupa. refnależy stosować tylko w bardzo szczególnych przypadkach; przez większość czasu wystarczy implementować rzeczy w bardziej funkcjonalny sposób.
Massimiliano Kraus

1

Aby tego uniknąć UnauthorizedAccessException, używam:

var files = GetFiles(@"C:\", "*.*", SearchOption.AllDirectories);
foreach (var file in files)
{
    Console.WriteLine($"{file}");
}

public static IEnumerable<string> GetFiles(string path, string searchPattern, SearchOption searchOption)
{
    var foldersToProcess = new List<string>()
    {
        path
    };

    while (foldersToProcess.Count > 0)
    {
        string folder = foldersToProcess[0];
        foldersToProcess.RemoveAt(0);

        if (searchOption.HasFlag(SearchOption.AllDirectories))
        {
            //get subfolders
            try
            {
                var subfolders = Directory.GetDirectories(folder);
                foldersToProcess.AddRange(subfolders);
            }
            catch (Exception ex)
            {
                //log if you're interested
            }
        }

        //get files
        var files = new List<string>();
        try
        {
            files = Directory.GetFiles(folder, searchPattern, SearchOption.TopDirectoryOnly).ToList();
        }
        catch (Exception ex)
        {
            //log if you're interested
        }

        foreach (var file in files)
        {
            yield return file;
        }
    }
}

1

Jeśli potrzebujesz tylko nazw plików, a ponieważ tak naprawdę nie podobało mi się większość rozwiązań (pod względem funkcji lub czytelności), co powiesz na to leniwe?

private void Foo()
{
  var files = GetAllFiles("pathToADirectory");
  foreach (string file in files)
  {
      // Use can use Path.GetFileName() or similar to extract just the filename if needed
      // You can break early and it won't still browse your whole disk since it's a lazy one
  }
}

/// <exception cref="T:System.IO.DirectoryNotFoundException">The specified path is invalid (for example, it is on an unmapped drive).</exception>
/// <exception cref="T:System.UnauthorizedAccessException">The caller does not have the required permission.</exception>
/// <exception cref="T:System.IO.IOException"><paramref name="path" /> is a file name.-or-A network error has occurred.</exception>
/// <exception cref="T:System.IO.PathTooLongException">The specified path, file name, or both exceed the system-defined maximum length. For example, on Windows-based platforms, paths must be less than 248 characters and file names must be less than 260 characters.</exception>
/// <exception cref="T:System.ArgumentNullException"><paramref name="path" /> is null.</exception>
/// <exception cref="T:System.ArgumentException"><paramref name="path" /> is a zero-length string, contains only white space, or contains one or more invalid characters as defined by <see cref="F:System.IO.Path.InvalidPathChars" />.</exception>
[NotNull]
public static IEnumerable<string> GetAllFiles([NotNull] string directory)
{
  foreach (string file in Directory.GetFiles(directory))
  {
    yield return file; // includes the path
  }

  foreach (string subDir in Directory.GetDirectories(directory))
  {
    foreach (string subFile in GetAllFiles(subDir))
    {
      yield return subFile;
    }
  }
}


0

Oto mój punkt widzenia, oparty na Hernaldo, jeśli chcesz znaleźć pliki o nazwach określonego wzorca, takie jak pliki XML, które gdzieś w ich nazwie zawierają określony ciąg znaków:

// call this like so: GetXMLFiles("Platypus", "C:\\");
public static List<string> GetXMLFiles(string fileType, string dir)
{
    string dirName = dir; 
    var fileNames = new List<String>();
    try
    {
        foreach (string f in Directory.GetFiles(dirName))
        {
            if ((f.Contains(fileType)) && (f.Contains(".XML")))
            {
                fileNames.Add(f);
            }
        }
        foreach (string d in Directory.GetDirectories(dirName))
        {
            GetXMLFiles(fileType, d);
        }
    }
    catch (Exception ex)
    {
        MessageBox.Show(ex.Message);
    }
    return fileNames;
}

0

Lista plików i folderów do modelu, niestandardowa implementacja.
Spowoduje to utworzenie pełnej listy wszystkich plików i folderów, zaczynając od katalogu początkowego.

public class DirOrFileModel
    {
        #region Private Members

        private string _name;
        private string _location;
        private EntryType _entryType;

        #endregion

        #region Bindings

        public string Name
        {
            get { return _name; }
            set
            {
                if (value == _name) return;
                _name = value;
            }
        }

        public string Location
        {
            get { return _location; }
            set
            {
                if (value == _location) return;
                _location = value;
            }
        }

        public EntryType EntryType
        {
            get { return _entryType; }
            set
            {
                if (value == _entryType) return;
                _entryType = value;
            }
        }

        public ObservableCollection<DirOrFileModel> Entries { get; set; }

        #endregion

        #region Constructor

        public DirOrFileModel()
        {
            Entries = new ObservableCollection<DirOrFileModel>();
        }

        #endregion
    }

    public enum EntryType
    {
        Directory = 0,
        File = 1
    }

Metoda:

 static DirOrFileModel DirSearch(DirOrFileModel startDir)
        {
            var currentDir = startDir;
            try
            {
                foreach (string d in Directory.GetDirectories(currentDir.Location))
                {
                    var newDir = new DirOrFileModel
                    {
                        EntryType = EntryType.Directory,
                        Location = d,
                        Name = Path.GetFileName(d)
                    };
                    currentDir.Entries.Add(newDir);

                    DirSearch(newDir);
                }

                foreach (string f in Directory.GetFiles(currentDir.Location))
                {
                    var newFile = new DirOrFileModel
                    {
                        EntryType = EntryType.File,
                        Location = f,
                        Name = Path.GetFileNameWithoutExtension(f)
                    };
                    currentDir.Entries.Add(newFile);
                }

            }
            catch (Exception excpt)
            {
                Console.WriteLine(excpt.Message);
            }
            return startDir;
        }

Stosowanie:

var dir = new DirOrFileModel
            {
                Name = "C",
                Location = @"C:\",
                EntryType = EntryType.Directory
            };

            dir = DirSearch(dir);

0

Krótkie i proste rozwiązanie

string dir = @"D:\PATH";

DateTime from_date = DateTime.Now.Date;
DateTime to_date = DateTime.Now.Date.AddHours(23);
var files = Directory.EnumerateFiles(dir, "*.*",SearchOption.AllDirectories).Select(i=>new FileInfo(i))
.Where(file=>file.LastWriteTime >= from_date && file.LastWriteTime <= to_date);
foreach(var fl in files)
    Console.WriteLine(fl.FullName);

0

Ten pomógł mi uzyskać wszystkie pliki w katalogu i podkatalogach, może być komuś pomocny. [Inspirowane powyższymi odpowiedziami]

static void Main(string[] args)
    {
        try
        {
            var root = @"G:\logs";
            DirectorySearch(root);
        }
        catch (Exception ex)
        {
            Console.WriteLine(ex.Message);
        }
        Console.ReadKey();
    }





public static void DirectorySearch(string root, bool isRootItrated = false)
{
    if (!isRootItrated)
    {
        var rootDirectoryFiles = Directory.GetFiles(root);
        foreach (var file in rootDirectoryFiles)
        {
            Console.WriteLine(file);
        } 
    }

    var subDirectories = Directory.GetDirectories(root);
    if (subDirectories?.Any() == true)
    {
        foreach (var directory in subDirectories)
        {
            var files = Directory.GetFiles(directory);
            foreach (var file in files)
            {
                Console.WriteLine(file);
            }
            DirectorySearch(directory, true);
        }
    }
}

0
var d = new DirectoryInfo(@"C:\logs");
var list = d.GetFiles("*.txt").Select(m => m.Name).ToList();

0

Niektóre ulepszone wersje z maksymalnym poziomem lvl, aby przejść do katalogu i opcją wykluczania folderów:

using System;
using System.IO;

class MainClass {
  public static void Main (string[] args) {

    var dir = @"C:\directory\to\print";
    PrintDirectoryTree(dir, 2, new string[] {"folder3"});
  }


  public static void PrintDirectoryTree(string directory, int lvl, string[] excludedFolders = null, string lvlSeperator = "")
  {
    excludedFolders = excludedFolders ?? new string[0];

    foreach (string f in Directory.GetFiles(directory))
    {
        Console.WriteLine(lvlSeperator+Path.GetFileName(f));
    } 

    foreach (string d in Directory.GetDirectories(directory))
    {
        Console.WriteLine(lvlSeperator + "-" + Path.GetFileName(d));

        if(lvl > 0 && Array.IndexOf(excludedFolders, Path.GetFileName(d)) < 0)
        {
          PrintDirectoryTree(d, lvl-1, excludedFolders, lvlSeperator+"  ");
        }
    }
  }
}

katalog wejściowy:

-folder1
  file1.txt
  -folder2
    file2.txt
    -folder5
      file6.txt
  -folder3
    file3.txt
  -folder4
    file4.txt
    file5.txt

dane wyjściowe funkcji (zawartość folderu 5 jest wykluczona z powodu limitu lvl, a zawartość folderu 3 jest wykluczona, ponieważ znajduje się w tablicy excelFolders):

-folder1
  file1.txt
  -folder2
    file2.txt
    -folder5
  -folder3
  -folder4
    file4.txt
    file5.txt

-1

Oto wersja kodu B. Clay Shannon niestatyczna dla plików Excel:

class ExcelSearcher
{
    private List<string> _fileNames;

    public ExcelSearcher(List<string> filenames)
    {
        _fileNames = filenames;
    }
    public List<string> GetExcelFiles(string dir, List<string> filenames = null)
    {

        string dirName = dir;
        var dirNames = new List<string>();
        if (filenames != null)
        {
            _fileNames.Concat(filenames);
        }
        try
        {
            foreach (string f in Directory.GetFiles(dirName))
            {
                if (f.ToLower().EndsWith(".xls") || f.ToLower().EndsWith(".xlsx"))
                {
                    _fileNames.Add(f);
                }
            }
            dirNames = Directory.GetDirectories(dirName).ToList();
            foreach (string d in dirNames)
            {
                GetExcelFiles(d, _fileNames);
            }
        }
        catch (Exception ex)
        {
            //Bam
        }
        return _fileNames;
    }

-1

Bardzo proste rozwiązanie, zwraca listę plików.

    public static List<string> AllFilesInFolder(string folder)
    {
        var result = new List<string>();

        foreach (string f in Directory.GetFiles(folder))
        {
            result.Add(f);
        }

        foreach (string d in Directory.GetDirectories(folder))
        {
            result.AddRange(AllFilesInFolder(d));
        }

        return result;
    }

-2
static void Main(string[] args)
        {
            string[] array1 = Directory.GetFiles(@"D:\");
            string[] array2 = System.IO.Directory.GetDirectories(@"D:\");
            Console.WriteLine("--- Files: ---");
            foreach (string name in array1)
            {
                Console.WriteLine(name);
            }
            foreach (string name in array2)
            {
                Console.WriteLine(name);
            }
                  Console.ReadLine();
        }

1
uhhh ... to nie jest rekurencyjne
mxmissile,
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.