-1

我正在用 Java 扫描一个文本文件并使用 Buffered Reader 逐行读取它。我在第 60 到第 80 位有一些文字。根据这个位置的文本,我需要决定是跳过该行还是从同一行读取一些数据。在这种情况下,如果我找到“END OF HEADER”,我需要跳过该行。我在这里使用了 80 的 bufferedreader.skip(line.lenght()) 来跳过该行并移至下一行以读取一些文本,但它再次给出了字符串超出范围的异常。

streamObs = new FileInputStream(obsFile);
inStreamObs = new InputStreamReader(streamObs);
buffStreamObs = new BufferedReader(inStreamObs);
BufferedReader in = new BufferedReader(new FileReader(obsFile));
String line="";
while((line = in.readLine()) != null)
{
  String typeField=line.substring(Math.min(line.length(),60),line.length());
  //System.out.println(typeField);
  typeField=typeField.trim();
  if (typeField.equals("RINEX VERSION / TYPE")) {
    System.out.println(" Current version:"+line.substring(5,9));
  }
  if (typeField.endsWith("TIME OF FIRST OBS")){
    System.out.println("Time of First Observation:"+ line.substring(2,44));
  }
  if (typeField.equals("END OF HEADER"))
  {
    in.skip(80);

  }
  System.out.println(line.substring(Math.min(line.length(),30),32));

}
4

2 回答 2

1

为了跳过一些循环迭代,您需要使用continue;

于 2015-02-03T13:54:15.940 回答
0

伙计,什么都不做。
in.readLine() 触发一个迭代器,在您调用该方法后将其索引设置为下一行。它返回迭代器所在的行并将迭代器索引加 1。

if (! typeField.equals("END OF HEADER"))
 {
 if (typeField.equals("RINEX VERSION / TYPE")) {
  System.out.println(" Current version:"+line.substring(5,9));
 }
 if (typeField.endsWith("TIME OF FIRST OBS")){
  System.out.println("Time of First Observation:"+ line.substring(2,44));
 }
  System.out.println(line.substring(Math.min(line.length(),30),32));
}

顺便说一句,不要对这样的事情使用固定值。定义私有最终字段或使用 getter 和 setter 来获取和/或更改值。30、32、2、44、5 和 9 不应是硬编码数字

于 2015-02-03T14:08:07.497 回答