循环仅删除第一个文件

时间:2012-11-22 20:14:25

标签: java file delete-file

我在删除所有选定文件时遇到问题。我要做的是点击“添加”后,选择的所有文件都移动到新文件夹,并在之前的文件夹中删除。一个文件工作正常。它删除并移动文件。但不止一个,只有第一个被删除。我的循环是识别每个文件而不是删除它们。我发布了actionevent。如果需要更多代码,请告诉我。我已经指出问题出在哪里,所以我认为,所以你不必搜索代码。

public void actionPerformed(ActionEvent e) {
    int returnValue = 0;
    int option = 0;
    File[] selectedFiles = new File[0];

    if (e.getActionCommand().equals("CLOSE")) System.exit(0);

    else if (e.getActionCommand().equals("ADD")) {
        JFileChooser chooser = new JFileChooser();
        chooser.setMultiSelectionEnabled(true);
        returnValue = chooser.showOpenDialog(this);         

        if (returnValue == JFileChooser.APPROVE_OPTION) {

            File[] file = chooser.getSelectedFiles();                   

            try {
                FileInputStream fstream = null;
                FileOutputStream ostream = null;

                for (int i = 0; i < file.length; i++) {

                   fstream = new FileInputStream(file[i]);
                           ostream = new      
                                       FileOutputStream(file[i].getName());

                    Path path = Paths.get(file[i].getPath());
                    byte[] fileArray;
                    fileArray = Files.readAllBytes(path);

                    listModel.add(0, file[i].getName());
                    selectedFilesList.setModel(listModel);
                                  //ostream.write(fileArray, 0, fileArray.length);

                }

                fstream.close();
                //ostream.close();

                try {

                    for(int i = 0; i < file.length; i++) {
//**----------------------->>>PROBLEM**                     
                    Files.delete(Paths.get(file[i].getPath()));
                    System.out.println(file[i].getName());

                    }


                } catch (NoSuchFileException x) {}
        System.err.format("%s: no such" + " file or directory%n")
                } catch (DirectoryNotEmptyException x) {
                    System.err.format("%s not empty%n");
                } catch (IOException x) {
                    // File permission problems are caught here.
                    System.err.println(x);
                } catch (Exception err) {
            }
        }

2 个答案:

答案 0 :(得分:4)

这可能是由于您未能在第一个循环中关闭文件流造成的。

            for (int i = 0; i < file.length; i++) {
               fstream = new FileInputStream(file[i]);
                       ostream = new      
                                   FileOutputStream(file[i].getName()); // This is never closed

                Path path = Paths.get(file[i].getPath());
                byte[] fileArray;
                fileArray = Files.readAllBytes(path);

                listModel.add(0, file[i].getName());
                selectedFilesList.setModel(listModel);
                              //ostream.write(fileArray, 0, fileArray.length);

            }

            fstream.close();  // Only the last input stream is closed 

应该更像

            for (int i = 0; i < file.length; i++) {
              try {
                 fstream = new FileInputStream(file[i]);
                 ostream = new      
                      FileOutputStream(file[i].getName());

                  Path path = Paths.get(file[i].getPath());
                  byte[] fileArray;
                  fileArray = Files.readAllBytes(path);

                  listModel.add(0, file[i].getName());
                  selectedFilesList.setModel(listModel);
                  //ostream.write(fileArray, 0, fileArray.length);
               } finally {
                 fstream.close();
                 ostream.close();
               }
            }

关闭您打开的相同数量的文件。

这可能会导致您的问题,方法是锁定除了一个文件之外的所有文件,这会阻止删除。

此外,您的catch异常块(last语句)不会对错误执行任何操作。

答案 1 :(得分:3)

不要移动那样的文件!

  1. 如果您使用的是Java 7,请查看此page

  2. 对于旧版本,请使用oldFile.renameTo(newFile)

  3. 编辑:要了解代码无法正常工作的原因,请使用调试器。我认为你的删除循环是由于异常而留下的。