gpt4 book ai didi

java - 使用两行文本的 StringTokenizer 出现问题

转载 作者:行者123 更新时间:2023-12-01 09:23:03 26 4
gpt4 key购买 nike

我有一个程序,它应该获取运行参数中指定的文本文件,并在单独的行上一次打印一个单词。它应该省略除破折号 (-) 和撇号 (') 之外的任何特殊字符。

我基本上已经完成了程序,只是我只能让它打印文件中的第一行文本。

以下是文本文件中的内容:

这是输入文件的第一行。它有不止一行!

这是我正在使用的运行参数:

java A1 A1.txt

这是我的代码:

import java.io.*;
import java.util.*;

public class A1
{
public static void main (String [] args) throws IOException
{
if (args.length > 0)
{
String file = (args[2]);

try
{
FileReader fr = new FileReader (file);
BufferedReader br = new BufferedReader(fr);
String s = br.readLine();
int i = 1;
StringTokenizer st = new StringTokenizer(s);
while (st.hasMoreTokens())
{
System.out.println(st.nextToken());

}
br.close();
} catch (IOException e)
{
System.out.println ("The following error occurred " + e);
}
}
}
}

最佳答案

您只调用了一次readLine()!因此,您只需读取和解析输入文件的第一行。然后程序结束。

您想要做的是将其放入 while 循环中并读取文件的每一行,直到到达末尾,如下所示:

while((s = br.readLine()) != null) {
StringTokenizer st = new StringTokenizer(s);
while (st.hasMoreTokens()) {
System.out.println(st.nextToken());
}
}

基本上,这意味着“当需要读取下一行时,对该行执行以下操作”。

关于java - 使用两行文本的 StringTokenizer 出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40031830/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com