Java Weka - 无法创建新的输出文件。使用标准输出

Java Weka - Cannot create a new output file. Standard out is used

提问人:Hack-R 提问时间:11/1/2016 最后编辑:Hack-R 更新时间:5/30/2017 访问量:1334

问:

我有一个 Java 程序,可以将 CSV 文件转换为 Weka 的 ARFF 格式。

它在任何给定会话中首次运行时都能完美运行,但随后总是失败并显示以下消息:

无法创建新的输出文件。使用标准输出。

程序如下:

import java.io.File;
import weka.core.Instances;
import weka.core.converters.ArffSaver;
import weka.core.converters.CSVLoader;

public class CSV2Arff {
      /**
   * takes 2 arguments:
   * - CSV input file
   * - ARFF output file
     * @param args
     * @throws java.lang.Exception
   */
  public static void main(String[] args) throws Exception {
    if (args.length != 2) {
      System.out.println("\nUsage: CSV2Arff <input.csv> <output.arff>\n");
      System.exit(1);
    }

    // load CSV
    CSVLoader loader = new CSVLoader();
    loader.setSource(new File(args[0]));
    Instances data = loader.getDataSet();

    // save ARFF
    ArffSaver saver = new ArffSaver();
    saver.setInstances(data);
    saver.setFile(new File(args[1]));
    //saver.setDestination(new File(args[1]));
    saver.writeBatch();
  }
}

来自控制台的完整错误:

Oct 31, 2016 3:53:39 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-nio-8080"]
Oct 31, 2016 3:53:39 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["ajp-nio-8009"]
Oct 31, 2016 3:53:39 PM org.apache.catalina.startup.Catalina start
INFO: Server startup in 6142 ms
Cannot create a new output file. Standard out is used.
java csv weka

评论

0赞 davidxxx 11/1/2016
你能显示所有的堆栈跟踪吗?
0赞 Kacper 11/1/2016
您是否始终使用相同的目标文件名调用 programm?
0赞 Hack-R 11/1/2016
@Kacper 是的,它应该覆盖文件。
0赞 Hack-R 11/1/2016
@davidxxx 当然,我现在要补充一下
0赞 davidxxx 11/1/2016
而在服务器日志(TOMCAT_HOME/logs)中,你没有更多细节吗?

答:

1赞 Kacper 11/1/2016 #1

我认为不会覆盖该文件。如果要覆盖它,请在设置为目标之前删除文件(如果存在)。如果您想要连接数据,请尝试ArffSaverwriteIncremental

你有:

saver.setFile(new File(args[1]));

我会选择这样的东西:

File f = new File(args[1]);
if(f.exists()) { 
    f.delete();
};
saver.setFile(new File(args[1]);

评论

0赞 Hack-R 11/1/2016
这对我来说是完全有意义的,但实际上它仍然会抛出相同的错误,“无法创建新的输出文件。使用标准输出。我尝试清理工作目录,刷新项目并重新启动Tomcat。
0赞 Kacper 11/1/2016
@Hack-R 您可以尝试保存到多个文件吗?只是为了确认问题出在使用单个文件时?int i = (int) Math.ceil(Math.random() * 10000); saver.setFile(new File(args[1] + i));
0赞 Kacper 11/1/2016
@Hack-R,我还略微更改了答案中的代码。如果您能够写入多个文件,则意味着重用文件有问题。如果您也收到文件名中附加数字的错误,则意味着我的想法是错误的。
0赞 Hack-R 11/1/2016
谢谢。我现在在家,所以我必须等到明天才能尝试,但我会继续对你的答案投赞成票。干杯。
3赞 Atilla Ozgur 11/1/2016 #2

根据weka邮件列表,此错误是文件问题。其他电子邮件建议使用 Java I/O 应用程序来保存 arff 文件。

This error is coming from the CSVSaver and indicates that it is unable 
to create the directory and/or file that you've specified. More than 
likely it is something to do with permissions on where it is trying to 
write to.

请尝试以下代码。

import java.io.FileWriter;
import java.io.BufferedWriter;
import java.io.File;
import weka.core.Instances;
import weka.core.converters.ArffSaver;
import weka.core.converters.CSVLoader;

public class CSV2Arff {
      /**
   * takes 2 arguments:
   * - CSV input file
   * - ARFF output file
     * @param args
     * @throws java.lang.Exception
   */
  public static void main(String[] args) throws Exception {
    if (args.length != 2) {
      System.out.println("\nUsage: CSV2Arff <input.csv> <output.arff>\n");
      System.exit(1);
    }

    // load CSV
    CSVLoader loader = new CSVLoader();
    loader.setSource(new File(args[0]));
    Instances data = loader.getDataSet();
    String fileName = args[1];


    // save ARFF
    BufferedWriter writer = new BufferedWriter(new FileWriter(fileName));
    writer.write(data.toString());
    writer.flush();
    writer.close();

  }
}