一个正则表达式,就是用某种模式去匹配一类字符串的一个公式
许多语言,包括Perl、PHP、Python、JavaScript 和 JScript,都支持用正则表达式处理文本,一些文本编辑器用正则表达式实现高级“搜索-替换” 功能
那么 Java 又怎样呢
本文写作时,一个包含了用正则表达式进行文本处理的Java规范需求(Specification Request)已经得到认可,你可以期待在 JDK 的下一版本中看到它
然而,如果现在就需要使用正则表达式,又该怎么办呢
你可以从 Apache
org 下载源代码开放的Jakarta-ORO 库
本文接下来的内容先简要地介绍正则表达式的入门知识,然后以 Jakarta-ORO API 为例介绍如何使用正则表达式
一、正则表达式基础知识 我们先从简单的开始
假设你要搜索一个包含字符“cat” 的字符串,搜索用的正则表达式就是“cat”
如果搜索对大小写不敏感,单词“catalog” 、“Catherine” 、“sophisticated” 都可以匹配
也就是说: 1
1 句点符号 假设你在玩英文拼字游戏,想要找出三个字母的单词,而且这些单词必须以“t” 字母开头,以“n” 字母结束
另外,假设有一本英文字典,你可以用正则表达式搜索它的全部内容
要构造出这个正则表达式,你可以使用一个通配符——句点符号“
这样,完整的表达式就是“t
n” ,它匹配“tan” 、“ten” 、“tin” 和“ton” ,还匹配“t#n” 、“tpn” 甚至“t n” ,还有其他许多无意义的组合
这是因为句点符号匹配所有字符,包括空格、Tab 字符甚至换行符: 1
2 方括号符号 为了解决句点符号匹配范围过于广泛这一问题,你可以在方括号(“[]” )里面指定看来有意义的字符
此时,只有方括号里面指定的字符才参与匹配
也就是说,正则表达