我正在用 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));
}