使用递归获取目录和文件

本文关键字:文件 获取 递归 | 更新日期: 2023-09-27 18:00:01

可以通过递归获取所有目录、子目录和文件。

我这样做是因为我想增加我的编程逻辑,并学习递归是如何工作的。

我知道这样做:

 string path = "D://";
            string rezdir,newpath;
            DirectoryInfo di = new DirectoryInfo(path);
            DirectoryInfo[] dir = di.GetDirectories().ToArray();
            for (int i = 0; i < di.GetDirectories().Length; i++)
            {
                Console.WriteLine(dir[i].ToString());
            }
            Console.WriteLine("'n'nChoose File: ");
            rezdir = Console.ReadLine();
            newpath = path + rezdir;
            di = new DirectoryInfo(newpath);
            dir = di.GetDirectories().ToArray();
            for (int i = 0; i < di.GetDirectories().Length; i++)
            {
                Console.WriteLine(dir[i].ToString());
            }
            Console.ReadKey();

但我不会用递归的方式来做这件事,所以如果有人能做到这一点,我会感谢他的。

使用递归获取目录和文件

根据你发布的代码-你似乎想要一些用户交互-所以试试这样的东西:

 public static class RecursiveTest
{
    public static string Foo(DirectoryInfo currentPath)
    {
        if (!currentPath.Exists) return string.Empty;
        foreach (var directory in currentPath.EnumerateDirectories())
            Console.WriteLine("Directory {0}", directory.Name);
        foreach (var file in currentPath.EnumerateFiles())
            Console.WriteLine("File {0}", file.Name);
        while(true)
        {
            Console.WriteLine("Choose directory or file: ");
            string chosenPath = Console.ReadLine();
            string newPath = Path.Combine(currentPath.FullName, chosenPath);
            if(Directory.Exists(newPath))
                return Foo(new DirectoryInfo(newPath));
            if(File.Exists(newPath))
                return newPath;
            Console.WriteLine("File {0} doesn't exist!", newPath);
        }
    }
}

用这样的东西打电话:

class Program
{
    static void Main(string[] args)
    {
        Console.WriteLine(RecursiveTest.Foo(new DirectoryInfo(@"d:'dev")));
        Console.ReadLine();
    }
}

HTH

我将避免编码,因为这是一个有价值的学习练习。试着自己完成:一旦完成,你就会知道你理解递归。

要进行递归,方法需要调用自己。想象一下的方法

public static void ShowDirectory(int indentationLevel, DirectoryInfo path)

已经为您编写了。这使得编写正文更容易:

  1. 获取目录中的所有文件,并在循环中打印它们的名称
  2. 获取目录中的所有目录,并在下一个缩进级别显示它们的内容。你需要另一个循环

第一步是编写循环的简单练习。第二个练习也变得很容易,因为您可以将ShowDirectory看作是预先编写的。

是的,这是可能的。但我建议你首先了解递归是什么。简单地说,递归有一个一次性执行的部分,和多次执行

在这个问题中,一次性执行部分可能是获取根目录下所有目录的列表。

然后,对于每个目录,您将获得所有的子目录和文件。这是多次部分。然而,要多次运行一批代码,您需要将它们捆绑到一个可调用的例程、过程、方法或函数中,无论您称之为什么。

public void DoDirectories()
{
    // one-time part; get a list of directories to start with.
    List<string> rootDirectories = Directory.GetDirectories("c:''").ToList();
    foreach (string rootDirectory in rootDirectories)
    {
        GetSubdirectories(rootDirectory);
    }
}
public List<string> GetSubdirectories(string parentDirectory)
{
    List<string> subdirecotries = Directory.GetDirectories(
        parentDirectory, "*.*", SearchOption.TopDirectoryOnly).ToList();
    foreach (string subdirectory in subdirecotries)
    {
        GetSubdirectories(subdirectory); // recursing happens here
    }
    return subdirecotries;
}