正则表达式匹配任意字符(包罗换行符)的写法

本日在Java中想利用正则表达式来获取一段文本中的任意字符。于是很随意得就写出如下匹配法则:
(.*)
功效运行之后才发明,无法得到换行之后的文本。于是查了一下手册,才发明正则表达式中,“.”(点标记)匹配的是除了换行符“\n”以外的所有字符。同时,手册上尚有一句话:要匹配包罗 '\n' 在内的任何字符,请利用像 '[.\n]' 的模式。于是我将正则表达式的匹配法则修改如下:
([.\n]*),虽然,假如是在java措施中直接写到话,需要改为([.\\n]*)
功效再次运行措施,发明什么内容也取不到了。我百思不得其解,又将其修改为如下法则:
([.|\n]*) 以及 ([\n.]*)
功效照旧不可,什么内容都取不到。看来点标记和换行符卯上劲了~
然后上网一查,固然没有查出上述法则到底是什么处所出问题了,可是查出了一个办理步伐,颠末一试,公然可以匹配包罗换行符在内的任意字符,以下为正确的正则表达式匹配法则:
([\s\S]*)
同时,也可以用 “([\d\D]*)”、“([\w\W]*)” 来暗示。


在文本文件里, 这个表达式可以匹配所有的英文
/[ -~]/
这个表达式可以匹配所有的非英文(好比中文)
/[^ -~]/
/是VI里用的. 你在editplus或措施里不需要/

您大概感乐趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wsdxsx.html