JDKJDK1.0 JDK1.7 Source java.io.File 객체 의 인스턴스 메소드 java.nio.file.Files 클래스의 정적 메소드 매개변수 매개변수 없음 java.nio.file.Path 반환 값boolean void 예외 선언선언 없음 선언에서 java.io.IOException 이 발생함 파일은 그렇지 않습니다 존재예외 발생 안 함, false 반환 java.nio.file.NoSuchFileException 발생 비어 있지 않은 디렉터리 삭제 삭제 불가, false 반환 삭제 불가, java.nio.file.DirectoryNotEmptyException 발생 점유된 파일 삭제삭제 불가, false 반환 삭제 불가, java.nio.file.FileSystemException 발생 다른 이유로 파일 삭제 불가예외 발생 불가, false 반환 Throw java.io.IOException 의 특정 하위 클래스如何删除整个目录或者目录中的部分文件 先造数据
private void createMoreFiles() throws IOException {
Files.createDirectories(Paths.get("D:\data\test1\test2\test3\test4\test5\"));
Files.write(Paths.get("D:\data\test1\test2\test2.log"), "hello".getBytes());
Files.write(Paths.get("D:\data\test1\test2\test3\test3.log"), "hello".getBytes());
} 로그인 후 복사
walkFileTree与FileVisitor 使用walkFileTree方法遍历整个文件目录树,使用FileVisitor处理遍历出来的每一项文件或文件夹
在去删除文件夹之前,该文件夹里面的文件已经被删除了。
@Test
void testDeleteFileDir5() throws IOException {
createMoreFiles();
Path path = Paths.get("D:\data\test1\test2");
Files.walkFileTree(path,
new SimpleFileVisitor<Path>() {
// 先去遍历删除文件
@Override
public FileVisitResult visitFile(Path file,
BasicFileAttributes attrs) throws IOException {
Files.delete(file);
System.out.printf("文件被删除 : %s%n", file);
return FileVisitResult.CONTINUE;
}
// 再去遍历删除目录
@Override
public FileVisitResult postVisitDirectory(Path dir,
IOException exc) throws IOException {
Files.delete(dir);
System.out.printf("文件夹被删除: %s%n", dir);
return FileVisitResult.CONTINUE;
}
}
);
} 로그인 후 복사
下面的输出体现了文件的删除顺序
文件被删除 : D:\data\test1\test2\test2.log
文件被删除 : D:\data\test1\test2\test3\test3.log
文件夹被删除 : D:\data\test1\test2\test3\test4\test5
文件夹被删除 : D:\data\test1\test2\test3\test4
文件夹被删除 : D:\data\test1\test2\test3
文件夹被删除 : D:\data\test1\test2
我们既然可以遍历出文件夹或者文件,我们就可以在处理的过程中进行过滤。比如:
按文件名删除文件或文件夹,参数Path里面含有文件或文件夹名称
按文件创建时间、修改时间、文件大小等信息去删除文件,参数BasicFileAttributes 里面包含了这些文件信息。
Files.walk 如果你对Stream流语法不太熟悉的话,这种方法稍微难理解一点,但是说实话也非常简单。
使用Files.walk遍历文件夹(包含子文件夹及子其文件),遍历结果是一个Stream
对每一个遍历出来的结果进行处理,调用Files.delete就可以了。
@Test
void testDeleteFileDir6() throws IOException {
createMoreFiles();
Path path = Paths.get("D:\data\test1\test2");
try (Stream<Path> walk = Files.walk(path)) {
walk.sorted(Comparator.reverseOrder())
.forEach(DeleteFileDir::deleteDirectoryStream);
}
}
private static void deleteDirectoryStream(Path path) {
try {
Files.delete(path);
System.out.printf("删除文件成功:%s%n",path.toString());
} catch (IOException e) {
System.err.printf("无法删除的路径 %s%n%s", path, e);
}
} 로그인 후 복사
问题:怎么能做到先去删除文件,再去删除文件夹?
利用的是字符串的排序规则,从字符串排序规则上讲,“D:\data\test1\test2”一定排在“D:\data\test1\test2\test2.log”的前面。
所以我们使用“sorted(Comparator.reverseOrder())”把Stream顺序颠倒一下,就达到了先删除文件,再删除文件夹的目的。
下面的输出,是最终执行结果的删除顺序。
删除文件成功:D:\data\test1\test2\test3\test4\test5
删除文件成功:D:\data\test1\test2\test3\test4
删除文件成功:D:\data\test1\test2\test3\test3.log
删除文件成功:D:\data\test1\test2\test3
删除文件成功:D:\data\test1\test2\test2.log
删除文件成功:D:\data\test1\test2
传统IO-递归遍历删除文件夹 传统的通过递归去删除文件或文件夹的方法就比较经典了
//传统IO递归删除
@Test
void testDeleteFileDir7() throws IOException {
createMoreFiles();
File file = new File("D:\data\test1\test2");
deleteDirectoryLegacyIO(file);
}
private void deleteDirectoryLegacyIO(File file) {
File[] list = file.listFiles(); //无法做到list多层文件夹数据
if (list != null) {
for (File temp : list) { //先去递归删除子文件夹及子文件
deleteDirectoryLegacyIO(temp); //注意这里是递归调用
}
}
if (file.delete()) { //再删除自己本身的文件夹
System.out.printf("删除成功 : %s%n", file);
} else {
System.err.printf("删除失败 : %s%n", file);
}
} 로그인 후 복사
需要注意的是:
listFiles()方法只能列出文件夹下面的一层文件或文件夹,不能列出子文件夹及其子文件。
先去递归删除子文件夹,再去删除文件夹自己本身。
위 내용은 Java에서 파일이나 폴더를 삭제하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
2024-10-13 13:32:21
2024-10-12 11:58:51
2024-10-11 20:06:51
2024-10-11 18:59:31
2024-10-11 18:30:51
2024-10-11 15:51:51
2024-10-11 15:42:10
2024-10-11 14:41:20
2024-10-11 14:08:31
2024-10-11 13:42:21