string.matches(“。*”)返回false


问题内容

在我的程序中,我有一个字符串(从外部库获取),该字符串与任何正则表达式都不匹配。

String content = // extract text from PDF
assertTrue(content.matches(".*")); // fails
assertTrue(content.contains("S P E C I A L")); // passes
assertTrue(content.matches("S P E C I A L")); // fails

知道有什么问题吗?当我打印content到标准输出时,看起来还可以。

这是从PDF提取文本的代码(我正在使用iText 5.0.1):

PdfReader reader = new PdfReader(source);
PdfTextExtractor extractor = new PdfTextExtractor(reader,
    new SimpleTextExtractingPdfContentRenderListener());
return extractor.getTextFromPage(1);

问题答案:

默认情况下,.不匹配的换行符。所以我的猜测是您content包含换行符。

还要注意,matches它将匹配整个字符串,而不仅仅是字符串的一部分:它不会做什么contains

一些例子:

String s = "foo\nbar";
System.out.println(s.matches(".*"));       // false
System.out.println(s.matches("foo"));      // false
System.out.println(s.matches("foo\nbar")); // true
System.out.println(s.matches("(?s).*"));   // true

(?s)最后一个例子将导致.匹配换行符也是如此。因此(?s).*将匹配任何字符串。