精通正则表达式:开篇

第一次接触正则表达式是在大二上学期学Java的时候,初次学习感觉这个东西很有意思,功能很强大,后来才发现,自己接触到的只是正则表达式的皮毛而已。在一次随手练习一个小程序时,它的强大再次震撼到了我,那是一个关于拉丁猪文字游戏的例子,基本规则是将一个英语单词的第一个辅音音素的字母移动到词尾并且加上后缀-ay(譬如“banana”会变成“anana-bay”):除了a、e、i、o、u,其余都是辅音,如果不用正则表达式,需要遍历先找到第一个辅音字母的位置,然后将该位置前后的字符串截取出来然后拼接或者将该位置替换为空字符,然后将找到的辅音字母拼接到后面,但是,如果用正则表达式有多快呢?

String regex = "([aeiou]*)([^eaiou])(.*)";
String s = "banana";
System.out.println(s.replaceAll(regex, "$1$3-$2ay"));

只需要三行就可以搞定。

于是我开始深入了解正则表达式,发现这货的强大远超我想象,就有了系统学习的想法,看到很多牛人都在推荐《精通正则表达式》这本书,下学期就到图书馆借来看了,坚持每天看一个小时,两个月看了前四章,后来因为做数据结构实验没时间停了下来。现在暑假来了,重新开始看,然后把以前看的也打算写下来。
另外,推荐一个学习正则表达式的网站:http://regexr.com/

你可能感兴趣的:(正则表达式)