根据关键字查找文件夹下的所有匹配文件《二》

来源:互联网 发布:html5 帝国cms 编辑:程序博客网 时间:2024/04/29 00:10
/** * 根据http://127.0.0.1:8080/cms/ReadAddress/1479805098158.jpg  读取图片  * @param imgUrl * @return * @throws Exception  */public String ReadAddress(String imgUrl) throws Exception {String path = Global.getDirPath();System.out.println(path);String image = imgUrl.substring(imgUrl.lastIndexOf("/")+1);System.out.println(image);File folder = new File(path);// 默认目录        String keyword = image;        if (!folder.exists()) {// 如果文件夹不存在            System.out.println("目录不存在:" + folder.getAbsolutePath());            return keyword;        }        File[] result = searchFile(folder, keyword);// 调用方法获得文件数组        System.out.println("在 " + folder + " 以及所有子文件时查找对象" + keyword);        System.out.println("查找了" + countFiles + " 个文件," + countFolders + " 个文件夹,共找到 " + result.length + " 个符合条件的文件:");        for (int i = 0; i < result.length; i++) {// 循环显示文件            File file = result[i];            System.out.println(file.getAbsolutePath() + " ");// 显示文件绝对路径        }return image;}//检索文件public static File[] searchFile(File folder, final String keyWord) {// 递归查找包含关键字的文件        File[] subFolders = folder.listFiles(new FileFilter() {// 运用内部匿名类获得文件            @Override            public boolean accept(File pathname) {// 实现FileFilter类的accept方法                if (pathname.isFile())// 如果是文件                    countFiles++;                else                    // 如果是目录                    countFolders++;                if (pathname.isDirectory()                        || (pathname.isFile() && pathname.getName().toLowerCase().contains(keyWord.toLowerCase())))// 目录或文件包含关键字                    return true;                return false;            }        });         List<File> result = new ArrayList<File>();// 声明一个集合        for (int i = 0; i < subFolders.length; i++) {// 循环显示文件夹或文件            if (subFolders[i].isFile()) {// 如果是文件则将文件添加到结果列表中                result.add(subFolders[i]);            } else {// 如果是文件夹,则递归调用本方法,然后把所有的文件加到结果列表中                File[] foldResult = searchFile(subFolders[i], keyWord);                for (int j = 0; j < foldResult.length; j++) {// 循环显示文件                    result.add(foldResult[j]);// 文件保存到集合中                }            }        }         File files[] = new File[result.size()];// 声明文件数组,长度为集合的长度        result.toArray(files);// 集合数组化        return files;    }



最后结果为:



0 0