2

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

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

我知道用这种方式做到这一点:

 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();

但是我不使用递归方式来做到这一点,所以有人可以做到这一点,我会很感激他。

4

3 回答 3

1

是的,有可能。但我确实建议您首先了解什么是递归。简单来说,递归有一次性执行部分和多次执行部分。那一次触发多次部分。

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

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

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;
}
于 2013-02-17T12:31:38.860 回答
1

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

要递归,方法需要调用自身。想象一个方法

public static void ShowDirectory(int indentationLevel, DirectoryInfo path)

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

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

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

于 2013-02-17T12:33:35.413 回答
1

按照您发布的代码 - 您似乎想要一些用户交互 - 所以尝试这样的事情:

 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();
    }
}

高温高压

于 2013-02-17T12:45:26.477 回答