0

我正在尝试读取目录,然后获取这些目录中文件的路径。问题是,我不知道一个文件夹里可能有多少个子目录,这段代码

NSString *path;
if ([[NSFileManager defaultManager] fileExistsAtPath:[[self downloadsDir] stringByAppendingPathComponent:[tableView cellForRowAtIndexPath:indexPath].textLabel.text]]) {
    path = [[self downloadsDir] stringByAppendingPathComponent:[NSString stringWithFormat:@"%@", [tableView cellForRowAtIndexPath:indexPath].textLabel.text]];
}
else{
    for (NSString *subdirs in [[NSFileManager defaultManager] contentsOfDirectoryAtPath:[self downloadsDir] error:nil]) {
        BOOL dir;
        [[NSFileManager defaultManager] fileExistsAtPath:[[self downloadsDir] stringByAppendingPathComponent:subdirs] isDirectory:&dir];
        if (dir) {
            for (NSString *f in [[NSFileManager defaultManager] contentsOfDirectoryAtPath:[[self downloadsDir] stringByAppendingPathComponent:subdirs] error:nil]) {
                if ([f isEqualToString:[tableView cellForRowAtIndexPath:indexPath].textLabel.text]) {
                    path = [[self downloadsDir] stringByAppendingPathComponent:[NSString stringWithFormat:@"%@/%@", subdirs, f]];
                }
            }
        }
    }
}

最多只能读取一个子目录,并为我提供我正在寻找的文件的路径。我找不到比这更好的方法来获取多个子目录以及这些目录中文件的路径。有人能帮忙吗?这是我想要做的事情

+Downloads Folder+
    +File1+ //I can get the path for this
    +Directory1+ 
         +Directory2+ 
             +File3+ // I want to get the path for this, but don't know how
         +File2+ // I can get the path for this

我觉得如果我只是不断重复获取目录内容的 for 循环,我最终可能会遇到问题。

4

1 回答 1

1

有一个叫做递归的概念,它通常应用于像这样的问题。基本上,您为每个子目录调用该方法,然后依次为每个子子目录调用它,依此类推。

重要的是你定义了一个停止点,所以它不会永远持续下去。似乎一个好的停止点是一个文件或一个空目录。

在伪代码中:

method storePaths(directory)
    for each element in  directory
        if element is a file
            store path
        else if element not empty directory
             call storePaths(element)
于 2013-04-10T22:12:18.903 回答