PHP正则函数各有专长:preg_match()单次匹配并提取首个结果;preg_match_all()全局匹配获取全部子串;preg_replace()按模式批量替换;preg_split()用正则灵活分割字符串;preg_grep()筛选数组中匹配正则的元素。

如果您在PHP中需要对字符串进行模式匹配、提取或替换操作,则必须调用内置的正则表达式函数。以下是几种常用且互不替代的正则函数调用方式及其适用场景:
一、使用 preg_match() 进行单次匹配
preg_match() 用于执行一次正则匹配,适用于判断字符串是否符合某模式或提取首个匹配结果。该函数返回1表示成功匹配,0表示未匹配,false表示发生错误。
1、定义目标字符串和正则表达式模式,例如 $subject = "联系电话:13812345678";$pattern = '/1[3-9]\d{9}/';
2、调用函数并传入参数:$result = preg_match($pattern, $subject, $matches);
立即学习“PHP免费学习笔记(深入)”;
3、检查返回值,若 $result === 1,则 $matches[0] 中保存首次匹配到的手机号;
4、注意:该函数仅匹配第一个符合条件的子串,不会继续搜索后续匹配项。
二、使用 preg_match_all() 获取全部匹配结果
preg_match_all() 用于全局匹配,可捕获所有符合正则模式的子串,并按顺序存入数组。适用于批量提取数据,如解析HTML标签内容或日志中的IP地址。
1、准备待处理文本,例如 $text = "订单号:ORD2023001,ORD2023002,ORD2023003";
2、编写带括号分组的模式:$pattern = '/ORD(\d{7})/i';
3、执行匹配:preg_match_all($pattern, $text, $allMatches, PREG_SET_ORDER);
4、遍历 $allMatches 获取每组完整匹配及子组,PREG_SET_ORDER 标志确保结果按匹配顺序组织为二维数组。
三、使用 preg_replace() 执行字符串替换
preg_replace() 根据正则模式查找并替换所有匹配内容,支持使用反向引用(如 $1、$2)动态构造替换字符串,适用于格式标准化或敏感词过滤。
1、设定原始字符串与替换规则,例如 $str = "价格:¥199.99,¥299.00";$pattern = '/¥(\d+\.\d{2})/';
2、指定替换模板:$replacement = 'USD$1';
3、调用函数:$newStr = preg_replace($pattern, $replacement, $str);
4、结果为 "价格:USD199.99,USD299.00",所有匹配项均被统一替换,不依赖循环手动处理。
四、使用 preg_split() 按正则分隔字符串
preg_split() 利用正则表达式作为分隔符将字符串切分为数组,比 explode() 更灵活,可处理多种分隔符组合或忽略空白边界。
1、定义待分割字符串,例如 $line = "apple, banana; orange|grape";
2、构造兼容多种分隔符的模式:$pattern = '/[,;|\\s]+/';
3、调用函数:$parts = preg_split($pattern, $line, -1, PREG_SPLIT_NO_EMPTY);
4、PREG_SPLIT_NO_EMPTY 标志可自动过滤空元素,避免因连续分隔符产生空字符串。
五、使用 preg_grep() 筛选数组元素
preg_grep() 对数组中的每个字符串元素执行正则匹配,并返回所有匹配成功的键值对,常用于日志分析或表单数据预检。
1、准备字符串数组:$emails = ['user@example.com', 'invalid-email', 'admin@test.org'];
2、编写邮箱校验模式:$pattern = '/^[^\s@]+@[^\s@]+\.[^\s@]+$/';
3、执行筛选:$valid = preg_grep($pattern, $emails);
4、返回结果仅包含合法邮箱,原始数组键名被保留,便于追溯来源位置。











