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