你可以使用边界匹配器来让正则表达式匹配得更加精确。例如,你可能对一行开始或结束的字符感兴趣,或者你可能想要知道匹配是否发生在单词边界,或者在上一个匹配的结束位置。下表列出了所有边界匹配器:

边界匹配器描述

^一行的开始

$一行的结束

\b单词的边界

\B非单词的边界

\A输入的开始

\G上一个匹配的结束

\Z输入的结束,除了最终终止符(如果有的话)

\z输入的结束

下面的例子演示边界匹配器 ^ 和 $,这里需要借助测试工具进行测试:

请输入正则表达式:^dog$

请输入检索文本:dog

检索到匹配文本"dog"从位置 0 到 3。

请输入正则表达式:^dog$

请输入检索文本: dog

没有检索到匹配的文本。

请输入正则表达式:\s*dog$

请输入检索文本: dog

检索到匹配文本" dog"从位置 0 到 15。

请输入正则表达式:^dog\w*

请输入检索文本:dogblahblah

检索到匹配文本"dogblahblah"从位置 0 到 11。

第一个例子可以成功是因为正则表达式匹配了整个输入文本。第二个例子失败是因为在输入文本的开始位置插入了空格。第三个正则表达式允许在 dog 前面添加任意多个空白字符。第四个正则表示 dog 必须出现在开始位置,后跟任意多个单词。

下面我们来测试一下如何匹配单词边界:

请输入正则表达式:\bdog\b

请输入检索文本:The dog plays in the yard.

检索到匹配文本"dog"从位置 4 到 7。

请输入正则表达式:\bdog\b

请输入检索文本:The doggie plays in the yard.

没有检索到匹配的文本。

使用非单词边界 \B 来替换:

请输入正则表达式:\bdog\B

请输入检索文本:The dog plays in the yard.

没有检索到匹配的文本。

请输入正则表达式:\bdog\B

请输入检索文本:The doggie plays in the yard.

检索到匹配文本"dog"从位置 4 到 7。

如果需要匹配发生在上一次匹配的结束位置,可使用 \G:

请输入正则表达式:dog

请输入检索文本:dog dog

检索到匹配文本"dog"从位置 0 到 3。

检索到匹配文本"dog"从位置 4 到 7。

请输入正则表达式:\Gdog

请输入检索文本:dog dog

检索到匹配文本"dog"从位置 0 到 3。

第二个例子只输出了一次,因为第二个 dog 并不是在上次匹配结束的位置开始的。