0

在一组随机的嵌套文件夹和文件中,我需要获取特定子文件夹名称为“x”的所有文件夹路径。

例如,在以下结构中,我只需要程序返回a\c\e\x

在此处输入图像描述

请注意,可以有任何级别的嵌套和任何文件夹结构。

更新:我已经能够编写一个基本程序来实现我想要的。但是,当在我之前的图表中在“dir d”下有一个目录“dir x”时,它会失败。所以程序返回 a\c\e\x 和 d\x。你能帮忙解决这个问题吗?

公共类僵尸{

String folderName= new String();
ArrayList folderList= new ArrayList(); 

public static void main(String[] args) {
    String path;
    try {
        path = new java.io.File(".").getCanonicalPath();
        Zombie zombie= new Zombie();
        getFilePaths(new File(path).listFiles(), zombie);


        Iterator itr = zombie.folderList.iterator();
        while (itr.hasNext())
            System.out.println(itr.next());

    } catch (IOException e) {
        e.printStackTrace();
    }
}

public static void getFilePaths(File[] fileList, Zombie zombie) {
    for (int i=0; i<fileList.length; i++) {
        File file= fileList[i];
        if (file.isDirectory()) {
            if (containsDesiredFolder(file)) {
                zombie.folderList.add(zombie.folderName+ "\\" + file.getName());
                zombie.folderName="";
            } else {
                if (containsFoldersNotFiles(file)) {
                    zombie.folderName= zombie.folderName + "\\" + file.getName();
                    getFilePaths(file.listFiles(), zombie);
                }
            }
        } 
    }
}   

public static boolean containsFoldersNotFiles(File file) {
    boolean flag = false;
    if (file.isFile()) return false;

    File[] dummyList = file.listFiles();

    //no file or folder present
    if (dummyList == null)
        return flag;

    for (int i = 0; i < dummyList.length; i++) {
        File dummyFile = dummyList[i];
        if (dummyFile.isDirectory() ) {
            return true;
        }
    }
    return flag;
}

public static boolean containsDesiredFolder(File file) {
    boolean flag = false;
    if (file.isFile()) return false;
    File[] dummyList = file.listFiles();

    if (dummyList == null)
        return flag;

    for (int i = 0; i < dummyList.length; i++) {
        File dummyFile = dummyList[i];
        if (dummyFile.isDirectory() && dummyFile.getName().equals("dirx")) {
            flag = true;
        }
    }
    return flag;
}

}

4

1 回答 1

0
  1. 获取种子文件夹,将其名称附加到字符串类型的 folder_list 变量中。
  2. 如果种子文件夹是 x 并且其子节点将文件夹列表添加到全局文件夹数组。
  3. 遍历种子文件夹的所有文件夹。在传递文件夹列表,并将每个子文件夹作为种子文件夹传递时,从 1 开始重复。

PS:这几乎可以。

于 2012-05-18T12:04:42.940 回答