从Eclipse中的文本文件中读取列式数据

时间:2016-10-07 09:11:55

标签: java eclipse cplex

我正在使用Eclipse与CPLEX协同工作来模拟车辆路径问题。我需要从文本文件中读取数据(请求点坐标,时间窗口等)。数据是按列的,因此我使用split函数将变量存储在其中。但是,控制台在第一行数据本身上显示错误。

代码:

public class VRP01k {
    public static void main(String args[]) throws FileNotFoundException{

    //Scanner input = new Scanner(new File("C:\\OR Research\\Code\\data01.txt"));
    Scanner input = new Scanner(new File("data01.txt"));

String line = input.nextLine();
      while(line != null) {
          String[] columns = line.split("\t");
          xPos[count] = Double.parseDouble(columns[0]);
          yPos[count] = Double.parseDouble(columns[1]);
          d[count] = Double.parseDouble(columns[2]);
          a[count] = Double.parseDouble(columns[3]);
          b[count] = Double.parseDouble(columns[4]);
          s[count] = Double.parseDouble(columns[5]);

          count++;
          line = input.nextLine();
    }

我尝试直接使用C盘中的文件并将其移动到我的Java项目中。两者都不起作用。错误如下:

Exception in thread "main" java.lang.NumberFormatException: For input string: "3.00      38.00       0.00       0.00    1187.00       0.00"
    at sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:2043)
    at sun.misc.FloatingDecimal.parseDouble(FloatingDecimal.java:110)
    at java.lang.Double.parseDouble(Double.java:538)
    at VRP01k.main(VRP01k.java:32)

数据文件的前几行是:

 3.00      38.00       0.00       0.00    1187.00       0.00
44.00      28.00       0.00     342.00     365.00       0.00
26.00      44.00       0.00      20.00      93.00       0.00
 7.00      41.00       0.00       0.00      45.00       0.00
17.00      28.00       0.00     250.00     292.00       0.00

请帮忙。感谢。

这是新代码:

public class VRP01k {
public static void main(String args[]) throws FileNotFoundException{

//Scanner input = new Scanner(new File("C:\\OR Research\\Code\\data01.txt"));
Scanner input = new Scanner(new File("data01.txt"));
    String line = input.nextLine();
         while(line != null) {
              String [] columns = line.trim().split("\\s+");
              xPos[count] = Double.parseDouble(columns[0]);
              yPos[count] = Double.parseDouble(columns[1]);
              d[count] = Double.parseDouble(columns[2]);
              a[count] = Double.parseDouble(columns[3]);
              b[count] = Double.parseDouble(columns[4]);
              s[count] = Double.parseDouble(columns[5]);

              count++;
              line = input.nextLine();
                }

错误:

Exception in thread "main" java.lang.NumberFormatException: empty String
    at sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:1842)
    at sun.misc.FloatingDecimal.parseDouble(FloatingDecimal.java:110)
    at java.lang.Double.parseDouble(Double.java:538)
    at VRP01k.main(VRP01k.java:32)

1 个答案:

答案 0 :(得分:0)

您的例外情况表明输入数字格式有错误:

"3.00      38.00       0.00       0.00    1187.00       0.00"

所以你的split实际上并没有拆分输入字符串而只是将整行传递给第一个Double.parseDouble

你很可能在数字之间有空白而不是标签。所以使用类似的东西:

String [] columns = line.trim().split("\\s+");

分裂。这是在进行拆分之前修剪前导和尾随空格以使事情更容易,然后在一个或多个空间上拆分。字符 - 这将处理空白和标签。