Chinaunix首页 | 论坛 | 博客
  • 博客访问: 12875829
  • 博文数量: 1293
  • 博客积分: 13501
  • 博客等级: 上将
  • 技术积分: 17974
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-08 18:11
文章分类

全部博文(1293)

文章存档

2019年(1)

2018年(1)

2016年(118)

2015年(257)

2014年(128)

2013年(222)

2012年(229)

2011年(337)

分类: 云计算

2016-04-26 17:15:16


在正则中,匹配任意字符,其实写法网上有很多,但因为各种软件或程序写法不支持等原因导致的问题,大家可以多研究。
今天在Java中想使用正则表达式来获取一段文本中的任意字符。于是很随意得就写出如下匹配规则: 
(.*) 
结果运行之后才发现,无法获得换行之后的文本。于是查了一下手册,才发现正则表达式中,“.”(点符号)匹配的是除了换行符“\n”以外的所有字符。同时,手册上还有一句话:要匹配包括 '\n' 在内的任何字符,请使用像 '[.\n]' 的模式。于是我将正则表达式的匹配规则修改如下: 
([.\n]*),当然,如果是在java程序中直接写到话,需要改为([.\\n]*) 
结果再次运行程序,发现什么内容也取不到了。我百思不得其解,又将其修改为如下规则: 
([.|\n]*) 以及 ([\n.]*) 
结果还是不行,什么内容都取不到。看来点符号和换行符卯上劲了~ 
然后上网一查,虽然没有查出上述规则到底是什么地方出问题了,但是查出了一个解决办法,经过一试,果然可以匹配包括换行符在内的任意字符,以下为正确的正则表达式匹配规则: 
([\s\S]*) 
同时,也可以用 “([\d\D]*)”、“([\w\W]*)” 来表示。 


转自网址:


阅读(3842) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~