我正在使用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)
答案 0 :(得分:0)
您的例外情况表明输入数字格式有错误:
"3.00 38.00 0.00 0.00 1187.00 0.00"
所以你的split
实际上并没有拆分输入字符串而只是将整行传递给第一个Double.parseDouble
。
你很可能在数字之间有空白而不是标签。所以使用类似的东西:
String [] columns = line.trim().split("\\s+");
分裂。这是在进行拆分之前修剪前导和尾随空格以使事情更容易,然后在一个或多个空间上拆分。字符 - 这将处理空白和标签。