我试图在JTextArea中使用正则表达式分割文本,通过\n分割字符串,然而,这并不奏效,我也尝试了\r\n|\r|n和许多其他正则表达式组合。 代码:

public void insertUpdate(DocumentEvent e) {
    String split[], docStr = null;
    Document textAreaDoc = (Document)e.getDocument();

    try {
        docStr = textAreaDoc.getText(textAreaDoc.getStartPosition().getOffset(), textAreaDoc.getEndPosition().getOffset());
    } catch (BadLocationException e1) {
        // TODO Auto-generated catch block
        e1.printStackTrace();
    }

    split = docStr.split("\\n");
}

当前回答

你不必在字符组中使用双转义字符。

对于所有非空行使用:

String.split("[\r\n]+")

其他回答

String#split (String正则表达式)方法使用正则表达式。由于Java 8 regex支持\R,它表示(来自Pattern类的文档):

Linebreak匹配器 \R任何Unicode换行符序列,相当于 (\ \ u000D \ u000A | u000A \ u000B \ u000C \ u000D \ u0085 \ u2028 \ u2029]

所以我们可以用它来匹配:

\u000D\000A -> \r\n对 \u000A ->换行(\n) \u000B ->行制表(不要与字符制表\t混淆,t是\u0009) \u000C -> form feed (\f) \u000D ->回车(\r) \u0085 -> next line (NEL) \u2028 ->分割线 \u2029 ->段分隔符

正如你所看到的,\r\n被放置在正则表达式的开头,这确保了正则表达式将首先尝试匹配这对,只有当匹配失败时,它才会尝试匹配单个字符的行分隔符。


所以如果你想拆分行分隔符,请使用split("\\R")。

如果您不想从结果数组中删除尾随空字符串“”,请使用split(regex, limit)和负的limit参数,如split("\\R", -1)。

如果您想将一个或多个连续空行作为单个分隔符,请使用split("\\R+")。

如果你不想要空行:

String.split("[\\r\\n]+")

有三种不同的惯例(可以说它们是事实上的标准)来设置和显示换行符:

回车+换行 换行 回车

在一些文本编辑器中,可以将其中一个替换为另一个:

最简单的方法是归一化到换行,然后拆分。

final String[] lines = contents.replace("\r\n", "\n")
                               .replace("\r", "\n")
                               .split("\n", -1);

这里给出的所有答案实际上都不尊重java对新行的定义,例如BufferedReader#readline。Java接受\n, \r和\r\n作为新行。一些答案匹配多个空行或格式错误的文件。E . g。当使用[\r\n]+时,<someothertext> \n\r\n<someothertext>将导致两行。

String lines[] = string.split("(\r\n|\r|\n)", -1);

相比之下,上面的答案具有以下性质:

它符合java对新行的定义,例如BufferedReader正在使用它 它不匹配多个新行 它不移除尾随的空行

你不必在字符组中使用双转义字符。

对于所有非空行使用:

String.split("[\r\n]+")