
PHP中如何匹配未格式化的@用户名?
在处理包含用户标记的Markdown文本时,我们常常需要对未被特定格式化的@用户名进行匹配。本文将探讨如何在PHP中编写正则表达式,以匹配未被格式化的@用户名,而忽略那些已经被正确格式化为[@用户名](链接)的文本。
假设我们有以下Markdown文本:
$markdownText =我们的目标是仅匹配未被格式化的@用户1,也就是说,不匹配已经以[@用户1](https://www.test.com/space/123)格式呈现的文本。
为了实现这一目标,我们需要考虑以下几个因素:
立即学习“PHP免费学习笔记(深入)”;
- 未格式化的@用户名:我们需要匹配文本中直接出现的@用户名,例如@用户1。
- 已格式化的@用户名:我们需要确保不匹配类似[@用户1](链接)的格式化文本,其中[和]可以包含空格和换行符,@前后也可以有空格,]和(之间没有空格。
针对这些需求,我们可以使用以下正则表达式来匹配未格式化的@用户名:
$pattern = '/(?这个正则表达式的详细解释如下:
- (?
- @[\w一-龥]:匹配@后面跟着一个或多个字母、数字或中文字符。
- (?![\s\n]*?\][\s\n]*?\():负向后发断言,确保@用户名后面没有]和(之间的可选空格或换行符。
现在,让我们将这个正则表达式应用于我们的示例文本,并查看结果:
$markdownText =执行这段代码后,我们会得到以下输出:
Array ( [0] => @用户1 )正如我们所期望的,仅匹配了未被格式化的@用户1。通过使用这个正则表达式,我们成功地实现了只匹配未格式化的@用户名的目标。











