1

到目前为止,这就是我为读取文本文件所做的工作,

   Scanner file = new Scanner(new File("sample.txt")).useDelimiter(".");
   ArrayList<String> arr = new ArrayList<>();
   while (file.hasNextLine()) {
      strList.add(file.nextLine());
   }
   file.close();
   for (int i = 0; i < arr.size(); i++) {
      System.out.println(arr.get(i));
   }

我的文本文件看起来像这样,

I love you. You
love me. He loves
her. She loves him.

我想要代码的结果,例如,

I love you
You love me
He loves her
She loves him

但结果与文本文件本身相同。这不是“useDelimiter(".")”假设用句点(“.”)分隔文本文件吗?

我也尝试使用 hasNext() 和 next() 而不是 hasNextLine() 和 nextLine(),但它会打印出空的 30ish 新行。

4

1 回答 1

3

那是因为useDelimiter 接受一个模式。点.是用于正则表达式的特殊字符,意思是“任何字符”。只需用反斜杠转义句点,它就会起作用:

Scanner file = new Scanner(new File("sample.txt")).useDelimiter("\\.");

编辑

问题是,您正在使用hasNextLine()并且nextLine()无法与您的新.分隔符一起正常工作。这是一个可以为您提供所需结果的工作示例:

import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class Test {

    final static String path = Test.class.getResource("sample.txt").getPath();

    public static void main(String[] args) throws IOException {
        Scanner file = new Scanner(new File(path)).useDelimiter("\\.");
        List<String> phrases = new ArrayList<String>();
        while (file.hasNext()) {
            phrases.add(file.next().trim().replace("\r\n", " ")); // remove new lines
        }
        file.close();

        for (String phrase : phrases) {
            System.out.println(phrase);
        }
    }
}

通过使用hasNext()and next(),我们可以使用我们的新.分隔符而不是默认的新行分隔符。但是,由于我们正在这样做,我们仍然会在您的段落中散布新行,这就是为什么我们需要删除新行,这是为了file.next().trim().replace("\r\n", " ")清理尾随空格并删除新换行符。

输入:

I love you. You
love me. He loves
her. She loves him.

输出:

I love you
You love me
He loves her
She loves him
于 2018-04-22T18:38:50.717 回答