Chcę utworzyć i usunąć katalog za pomocą Java, ale to nie działa.
File index = new File("/home/Work/Indexer1");
if (!index.exists()) {
index.mkdir();
} else {
index.delete();
if (!index.exists()) {
index.mkdir();
}
}
Chcę utworzyć i usunąć katalog za pomocą Java, ale to nie działa.
File index = new File("/home/Work/Indexer1");
if (!index.exists()) {
index.mkdir();
} else {
index.delete();
if (!index.exists()) {
index.mkdir();
}
}
Odpowiedzi:
Java nie może usunąć folderów zawierających dane. Musisz usunąć wszystkie pliki przed usunięciem folderu.
Użyj czegoś takiego:
String[]entries = index.list();
for(String s: entries){
File currentFile = new File(index.getPath(),s);
currentFile.delete();
}
Wtedy powinieneś być w stanie usunąć folder za pomocą index.delete()
Untested!
FileUtils.deleteDirectory
jak powiedział @Francesco Menzani.
if (!index.delete()) {...}
. Następnie, jeśli indeks jest dowiązaniem symbolicznym, jest usuwany niezależnie od tego, czy wygląda na to, że ma zawartość.
entries
jest pusty.
Tylko jeden wiersz.
import org.apache.commons.io.FileUtils;
FileUtils.deleteDirectory(new File(destination));
Dokumentacja tutaj
To działa i chociaż pomijanie testu katalogu wydaje się nieefektywne, tak nie jest: test jest wykonywany od razu w listFiles()
.
void deleteDir(File file) {
File[] contents = file.listFiles();
if (contents != null) {
for (File f : contents) {
deleteDir(f);
}
}
file.delete();
}
Zaktualizuj, aby uniknąć następujących dowiązań symbolicznych:
void deleteDir(File file) {
File[] contents = file.listFiles();
if (contents != null) {
for (File f : contents) {
if (! Files.isSymbolicLink(f.toPath())) {
deleteDir(f);
}
}
}
file.delete();
}
Wolę to rozwiązanie w java 8:
Files.walk(pathToBeDeleted)
.sorted(Comparator.reverseOrder())
.map(Path::toFile)
.forEach(File::delete);
Z tej witryny: http://www.baeldung.com/java-delete-directory
Files.walk()
, co jest wyraźnie wskazane w dokumentacji interfejsu API. Wiem, że jeśli nie zamkniesz strumienia zwróconego Files.list()
na przykład przez, możesz zabraknąć uchwytów i program się zawiesi. Zobacz np. Stackoverflow.com/q/36990053/421049 i stackoverflow.com/q/26997240/421049 .
W JDK 7 można było używać Files.walkFileTree()
i Files.deleteIfExists()
usuwać drzewo plików. (Przykład: http://fahdshariff.blogspot.ru/2011/08/java-7-deleting-directory-by-walking.html )
W JDK 6 jednym z możliwych sposobów jest użycie FileUtils.deleteQuietly z Apache Commons, które usunie plik, katalog lub katalog z plikami i podkatalogami.
Korzystając z Apache Commons-IO, jest to jeden wiersz:
import org.apache.commons.io.FileUtils;
FileUtils.forceDelete(new File(destination));
Jest to (nieco) bardziej wydajne niż FileUtils.deleteDirectory
.
Jak wspomniano, Java nie może usunąć folderu zawierającego pliki, dlatego najpierw usuń pliki, a następnie folder.
Oto prosty przykład, jak to zrobić:
import org.apache.commons.io.FileUtils;
// First, remove files from into the folder
FileUtils.cleanDirectory(folder/path);
// Then, remove the folder
FileUtils.deleteDirectory(folder/path);
Lub:
FileUtils.forceDelete(new File(destination));
Moja podstawowa wersja rekurencyjna, działająca ze starszymi wersjami JDK:
public static void deleteFile(File element) {
if (element.isDirectory()) {
for (File sub : element.listFiles()) {
deleteFile(sub);
}
}
element.delete();
}
listFiles()
zwraca null, zamiast wywoływać isDirectory()
.
To najlepsze rozwiązanie dla Java 7+
:
public static void deleteDirectory(String directoryFilePath) throws IOException
{
Path directory = Paths.get(directoryFilePath);
if (Files.exists(directory))
{
Files.walkFileTree(directory, new SimpleFileVisitor<Path>()
{
@Override
public FileVisitResult visitFile(Path path, BasicFileAttributes basicFileAttributes) throws IOException
{
Files.delete(path);
return FileVisitResult.CONTINUE;
}
@Override
public FileVisitResult postVisitDirectory(Path directory, IOException ioException) throws IOException
{
Files.delete(directory);
return FileVisitResult.CONTINUE;
}
});
}
}
Na ratunek guawa 21+. Używaj tylko wtedy, gdy nie ma dowiązań symbolicznych wskazujących na katalog do usunięcia.
com.google.common.io.MoreFiles.deleteRecursively(
file.toPath(),
RecursiveDeleteOption.ALLOW_INSECURE
) ;
(To pytanie jest dobrze zindeksowane przez Google, więc inne osoby używające guawy mogą być szczęśliwe, gdy znajdą tę odpowiedź, nawet jeśli jest ona zbędna w przypadku innych odpowiedzi w innych miejscach).
Najbardziej podoba mi się to rozwiązanie. Nie korzysta z biblioteki innej firmy, zamiast tego używa NIO2 Java 7.
/**
* Deletes Folder with all of its content
*
* @param folder path to folder which should be deleted
*/
public static void deleteFolderAndItsContent(final Path folder) throws IOException {
Files.walkFileTree(folder, new SimpleFileVisitor<Path>() {
@Override
public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException {
Files.delete(file);
return FileVisitResult.CONTINUE;
}
@Override
public FileVisitResult postVisitDirectory(Path dir, IOException exc) throws IOException {
if (exc != null) {
throw exc;
}
Files.delete(dir);
return FileVisitResult.CONTINUE;
}
});
}
W tym
index.delete();
if (!index.exists())
{
index.mkdir();
}
dzwonisz
if (!index.exists())
{
index.mkdir();
}
po
index.delete();
Oznacza to, że tworzysz plik ponownie po usunięciu
File.delete () zwraca wartość logiczną, więc jeśli chcesz sprawdzić, zrób, System.out.println(index.delete());
jeśli otrzymasz, true
oznacza to, że plik został usunięty
File index = new File("/home/Work/Indexer1");
if (!index.exists())
{
index.mkdir();
}
else{
System.out.println(index.delete());//If you get true then file is deleted
if (!index.exists())
{
index.mkdir();// here you are creating again after deleting the file
}
}
z komentarzy podanych poniżej, zaktualizowana odpowiedź jest taka
File f=new File("full_path");//full path like c:/home/ri
if(f.exists())
{
f.delete();
}
else
{
try {
//f.createNewFile();//this will create a file
f.mkdir();//this create a folder
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
Jeśli masz podfoldery, napotkasz problemy z odpowiedziami Cemron. więc powinieneś stworzyć metodę, która działa tak:
private void deleteTempFile(File tempFile) {
try
{
if(tempFile.isDirectory()){
File[] entries = tempFile.listFiles();
for(File currentFile: entries){
deleteTempFile(currentFile);
}
tempFile.delete();
}else{
tempFile.delete();
}
getLogger().info("DELETED Temporal File: " + tempFile.getPath());
}
catch(Throwable t)
{
getLogger().error("Could not DELETE file: " + tempFile.getPath(), t);
}
}
Możesz użyć FileUtils.deleteDirectory . JAVA nie może usunąć niepustych folderów za pomocą File.delete () .
Directry nie może po prostu usunąć, jeśli zawiera pliki, więc może być konieczne usunięcie najpierw plików, a następnie katalogu
public class DeleteFileFolder {
public DeleteFileFolder(String path) {
File file = new File(path);
if(file.exists())
{
do{
delete(file);
}while(file.exists());
}else
{
System.out.println("File or Folder not found : "+path);
}
}
private void delete(File file)
{
if(file.isDirectory())
{
String fileList[] = file.list();
if(fileList.length == 0)
{
System.out.println("Deleting Directory : "+file.getPath());
file.delete();
}else
{
int size = fileList.length;
for(int i = 0 ; i < size ; i++)
{
String fileName = fileList[i];
System.out.println("File path : "+file.getPath()+" and name :"+fileName);
String fullPath = file.getPath()+"/"+fileName;
File fileOrFolder = new File(fullPath);
System.out.println("Full Path :"+fileOrFolder.getPath());
delete(fileOrFolder);
}
}
}else
{
System.out.println("Deleting file : "+file.getPath());
file.delete();
}
}
Możesz wykonać wywołanie rekurencyjne, jeśli istnieją podkatalogi
import java.io.File;
class DeleteDir {
public static void main(String args[]) {
deleteDirectory(new File(args[0]));
}
static public boolean deleteDirectory(File path) {
if( path.exists() ) {
File[] files = path.listFiles();
for(int i=0; i<files.length; i++) {
if(files[i].isDirectory()) {
deleteDirectory(files[i]);
}
else {
files[i].delete();
}
}
}
return( path.delete() );
}
}
możemy użyć spring-core
zależności;
boolean result = FileSystemUtils.deleteRecursively(file);
Większość odpowiedzi (nawet ostatnich) odnoszących się do klas JDK polega na File.delete()
tym, że jest to wadliwy interfejs API, ponieważ operacja może zakończyć się cichym niepowodzeniem.
Dokumentacja java.io.File.delete()
metody stwierdza:
Zauważ, że
java.nio.file.Files
klasa definiujedelete
metodę zgłaszania,IOException
gdy nie można usunąć pliku. Jest to przydatne przy zgłaszaniu błędów i diagnozowaniu, dlaczego pliku nie można usunąć.
Jako zamiennik powinieneś preferować, Files.delete(Path p)
że wyrzuca komunikat IOException
z komunikatem o błędzie.
Rzeczywisty kod można napisać na przykład:
Path index = Paths.get("/home/Work/Indexer1");
if (!Files.exists(index)) {
index = Files.createDirectories(index);
} else {
Files.walk(index)
.sorted(Comparator.reverseOrder()) // as the file tree is traversed depth-first and that deleted dirs have to be empty
.forEach(t -> {
try {
Files.delete(t);
} catch (IOException e) {
// LOG the exception and potentially stop the processing
}
});
if (!Files.exists(index)) {
index = Files.createDirectories(index);
}
}
możesz spróbować w następujący sposób
File dir = new File("path");
if (dir.isDirectory())
{
dir.delete();
}
Jeśli w folderze znajdują się podfoldery, może być konieczne ich rekurencyjne usuwanie.
private void deleteFileOrFolder(File file){
try {
for (File f : file.listFiles()) {
f.delete();
deleteFileOrFolder(f);
}
} catch (Exception e) {
e.printStackTrace(System.err);
}
}
import org.apache.commons.io.FileUtils;
List<String> directory = new ArrayList();
directory.add("test-output");
directory.add("Reports/executions");
directory.add("Reports/index.html");
directory.add("Reports/report.properties");
for(int count = 0 ; count < directory.size() ; count ++)
{
String destination = directory.get(count);
deleteDirectory(destination);
}
public void deleteDirectory(String path) {
File file = new File(path);
if(file.isDirectory()){
System.out.println("Deleting Directory :" + path);
try {
FileUtils.deleteDirectory(new File(path)); //deletes the whole folder
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
else {
System.out.println("Deleting File :" + path);
//it is a simple file. Proceed for deletion
file.delete();
}
}
Działa jak marzenie . Zarówno w przypadku folderów, jak i plików. Salam :)
Usuń go z innej części
File index = new File("/home/Work/Indexer1");
if (!index.exists())
{
index.mkdir();
System.out.println("Dir Not present. Creating new one!");
}
index.delete();
System.out.println("File deleted successfully");
Niektóre z tych odpowiedzi wydają się niepotrzebnie długie:
if (directory.exists()) {
for (File file : directory.listFiles()) {
file.delete();
}
directory.delete();
}
Działa również dla podkatalogów.
Możesz użyć tej funkcji
public void delete()
{
File f = new File("E://implementation1/");
File[] files = f.listFiles();
for (File file : files) {
file.delete();
}
}