获取特定的文件夹路径

时间:2012-05-17 12:06:17

标签: file recursion directory

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

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

enter image description here

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

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

公共课Zombie {

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

}

1 个答案:

答案 0 :(得分:0)

  1. 获取种子文件夹,将其名称附加到string类型的folder_list变量中。
  2. 如果种子文件夹是x且其子节点将folder_list添加到全局folder_array。
  3. 遍历种子文件夹的所有文件夹。传递folder_list,并将每个子文件夹作为种子文件夹从1重复。
  4. PS:这几乎可以。