登录
首页 >  文章 >  php教程

正则表达式@@(.*?)@@的作用是匹配被@@包围的占位符内容。以下是详细说明:✅正则表达式解释@@:匹配两个@符号,作为占位符的开始和结束。*`(.?)**:这是一个**非贪婪匹配**,表示尽可能少地匹配字符,直到遇到下一个@@`。():表示捕获组,用于提取匹配的内容。.*?:匹配任意字符(包括空字符),但是非贪婪模式,即匹配到最短可能的字符串。🔍示例代码说明$string="这是一个测试@@t

时间:2026-03-22 13:09:49 225浏览 收藏

本文深入解析了在 PHP 中如何精准提取形如 @@xxx@@ 的双@占位符,强调必须使用 preg_match_all() 配合严谨的正则模式(如 '/@@[a-zA-Z0-9_]+@@/')才能可靠捕获全部有效占位符,彻底规避常见陷阱——如误用 preg_match() 导致漏匹配、采用 [^a-z] 等错误字符类引发乱匹配、或依赖 .*? 引发跨界误捕;同时提供提取纯标识符名称、支持中文 Unicode、大小写控制等实用进阶方案,助你构建健壮的模板解析、动态文案生成与配置处理逻辑。

PHP 正则表达式提取双@包围的占位符(如 @@token@@)

本文详解如何使用 preg_match_all() 配合正确正则模式,从字符串中精准提取所有形如 @@xxx@@ 的占位符,并返回完整匹配数组。

本文详解如何使用 preg_match_all() 配合正确正则模式,从字符串中精准提取所有形如 @@xxx@@ 的占位符,并返回完整匹配数组。

在 PHP 开发中,常需从模板字符串中提取自定义占位符(如 @@address@@、@@user_name@@),用于后续变量替换或内容解析。这类占位符统一以两个 @ 符号起止,中间为大小写字母、数字或下划线组成的标识符。若错误使用 preg_match() 或正则表达式不严谨,将导致仅匹配首个结果、漏匹配、甚至完全失配。

✅ 正确做法:使用 preg_match_all() + 精准模式

preg_match() 仅返回第一个匹配项,而 preg_match_all() 才能捕获全部匹配结果。同时,原始正则 /@@[^a-z]@@/ 存在两个关键问题:

  • [^a-z] 表示“非小写字母”,会匹配空格、@、数字等意外字符,逻辑与需求相反;
  • 缺少量词(如 + 或 *),无法匹配多字符标识符(如 address 是 7 个字母,而非 1 个)。

✅ 推荐正则模式:

'/@@[a-zA-Z0-9_]+@@/'
  • [a-zA-Z0-9_]:明确允许大小写字母、数字和下划线(符合常见 token 命名规范);
  • +:确保匹配一个及以上字符,避免 @@@@ 这类无效空占位符;
  • 整体包裹在定界符 / 中,简洁安全。

? 完整示例代码

<?php
$input = 'my address is @@address@@ and my house is at @@street@@ and the number is @@number@@ or so @@user_name@@';

// 使用 preg_match_all 获取全部匹配(注意:$matches 是二维数组)
preg_match_all('/@@[a-zA-Z0-9_]+@@/', $input, $matches);

// $matches[0] 是完整匹配结果的一维数组
$output = $matches[0];

print_r($output);
?>

输出结果:

Array
(
    [0] => @@address@@
    [1] => @@street@@
    [2] => @@number@@
    [3] => @@user_name@@
)

⚠️ 注意事项与进阶建议

  • 区分大小写:当前模式 a-zA-Z 支持大小写,如需严格小写可简化为 [a-z0-9_]+;
  • 支持中文或 Unicode:若 token 可含中文,改用 '/@@[\p{L}\p{N}_]+@@/u'(需 u 修饰符启用 Unicode 模式);
  • 避免过度匹配:勿用 .*? 等模糊表达式(如 /@@.*?@@/),可能跨占位符误匹配(例如 @@a@@b@@c@@ 中匹配到 @@a@@b@@);
  • 提取纯名称(不含 @@):若只需 address、street 等内部值,可使用捕获组:
    preg_match_all('/@@([a-zA-Z0-9_]+)@@/', $input, $matches);
    $names = $matches[1]; // $matches[1] 存储第一个捕获组内容

掌握该模式后,即可稳健支撑模板引擎、配置解析、动态文案生成等典型场景——核心在于:选对函数(preg_match_all)、写对模式(字符集 + 量词)、验证边界(避免贪婪/跨界)

以上就是《正则表达式@@(.*?)@@的作用是匹配被@@包围的占位符内容。以下是详细说明:✅正则表达式解释@@:匹配两个@符号,作为占位符的开始和结束。*`(.?)**:这是一个**非贪婪匹配**,表示尽可能少地匹配字符,直到遇到下一个@@`。():表示捕获组,用于提取匹配的内容。.*?:匹配任意字符(包括空字符),但是非贪婪模式,即匹配到最短可能的字符串。🔍示例代码说明$string="这是一个测试@@token@@,还有@@user@@。";preg_match_all('/@@(.*?)@@/',$string,$matches);print_r($matches[1]);输出结果:Array([0]=>token[1]=>user)$matches[1]是第一个捕获组的结果,也就是@@...@@中间的内容。preg_match_all()会找到所有匹配项,并将它们放入数组中。🔄替换占位符的方法方法一:使用preg_replace_callback()如果你需要根据匹配内容动态替换占位符,可以使用回调函数:$string=》的详细内容,更多关于的资料请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>