[英]How can you in Java list all files recursively in a folder that do not match an array of extensions?
我正在制作一个简单的程序,该程序递归遍历目录并删除所有与用户选择的文件扩展名不匹配的文件。 (本质上,我正在重新编写用PHP编写的脚本来帮助自学Java)
该方法工作正常,除了它返回与扩展名数组匹配的文件数组。 这将删除错误的文件。 如何退回不匹配的文件?
我正在使用org.apache.commons.io.FileUtils和字符串数组来获取文件:
import java.io.File;
import java.util.List;
import java.io.IOException;
import org.apache.commons.io.FileUtils;
public class Recurse {
// The method that takes a directory path (file object called folder) and a string of extensions
public static List<File> getFiles(final File folder, String[] extensions) throws IOException{
List<File> fileList = (List<File>) FileUtils.listFiles(folder, extensions, true);
return fileList;
}
}
我发现仅使用一种文件类型的示例,例如“ .txt”,但找不到用于数组的文件类型。 我宁愿坚持使用org.apache.commons.io.FileUtils,但我愿意更改我的方法。
使用File.listFiles(),并使用java.io.FileFilter。 您编写过滤器以检查文件名并确定该文件是否“通过”过滤器。 用不需要的扩展名数组实例化过滤器。 您没有使用FileUtils,但是除了标准Java库之外,您不需要任何东西。
-
请求后进行编辑,例如
public class NotTheseExtensions implements java.io.FileFilter
{
private ArrayList<String> extensions;
public NotTheseExtensions(ArrayList<String> extensions)
{
this.extensions = extensions;
}
public boolean accept(String filename)
{
boolean result = true;
boolean inList = false; // set this in your own logic
// logic to get the extension from the filename and look to see if it is
// in your list -- hopefully I don't have to write that for you as well.
if (inList) { result = false; }
return result;
}
}
现在,查看java.io.File中listFiles的(各种)签名。 其中之一采用了这种文件过滤器。 当给定此过滤器时,只有通过文件过滤器的东西(即,在上面的accept()方法中返回true的东西)才会由listFiles()返回。
我同意rcook的答案,但如果你真的想坚持FileUtils
,这里是一个选择:让所有的文件,然后删除匹配的扩展名的人。
List<File> all = (List<File>) FileUtils.listFiles(folder, null, true);
List<File> unwanted = (List<File>) FileUtils.listFiles(folder, extensions, true);
all.removeAll(unwanted);
return all;
请注意,这有点浪费,涉及通过文件系统进行两次递归。
您可以获取目录中的所有文件,然后删除不需要的扩展名而获得的文件。
我用它来获取具有特定扩展名的文件:
File dir = new File(fileDir);
FileFilter fileFilter = new WildcardFileFilter("*.txt");
File[] files = dir.listFiles(fileFilter);
这是使用FileUtils
的纯Java替代方法,避免了我的其他答案的效率问题并支持递归。 这涉及很多代码,我想我更喜欢FileUtils
解决方案。
public void myMethod() {
List<File> files = recursiveList(folder, new String[] { "jpg", "png" });
// ... do something ...
}
private List<File> recursiveList(File folder, String[] rejectedExtensions) {
List<File> files = new ArrayList<File>();
for (File subfolder : folder.listFiles(new DirectoryFilter())) {
files.addAll(recursiveList(subfolder, rejectedExtensions));
}
files.addAll(Arrays.asList(folder.listFiles(new ExtensionFilter(rejectedExtensions))));
return files;
}
private class DirectoryFilter implements FileFilter {
@Override
public boolean accept(File file) {
return file.isDirectory();
}
}
private class ExtensionFilter implements FileFilter {
private final String[] rejectedExtensions;
public ExtensionFilter(String[] rejectedExtensions) {
this.rejectedExtensions = rejectedExtensions;
}
@Override
public boolean accept(File file) {
if (file.isDirectory()) {
return false;
}
String name = file.getName();
for (String rejectedExtension : rejectedExtensions) {
if (name.endsWith(rejectedExtension)) {
return false;
}
}
return true;
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.