定义和用法
preg_match() 函数用于进行正则表达式匹配,成功返回 1 ,否则返回 0 。
preg_match() 匹配成功一次后就会停止匹配,如果要实现全部结果的匹配,则需使用 preg_match_all() 函数。
语法
- preg_match (pattern , subject, matches)
参数 | 描述 |
---|---|
pattern | 正则表达式 |
subject | 需要匹配检索的对象 |
matches | 可选,存储匹配结果的数组 |
例子 1
- <?php
- // 模式定界符后面的 "i" 表示不区分大小写字母的搜索
- if (preg_match ("/hi/i", "Welcome to hi-docs.com.")) {
- echo "A match was found.";
- } else {
- echo "A match was not found.";
- }
- ?>
输出:
- A match was found.
例子 2
匹配字符串中的url超链接
- <?php
- $urls = '<h3><a target="_blank" href="/php/preg_match.html"><span class="hl">preg</span>_match()</a></h3><p>[<a href="/Php.html">PHP</a>] 进行正则表达式匹配<br/><em>适用版本:5</em></p></dd><dd><h3><a target="_blank" href="/php/preg_match_all.html"><span class="hl">preg</span>_match_all()</a></h3>';
- if(preg_match("/<a[^>]*?href=\"([^>]+?)\"[^>]*?>.+?<\/a>/i", $urls ,$match)) {
- print_r($match);
- } else {
- echo "不匹配.";
- }
- ?>
输出:
- Array
- (
- [0] => <a target="_blank" href="/php/preg_match.html"><span class="hl">preg</span>_match()</a>
- [1] => /php/preg_match.html
- )
例子3
使用正则表达式匹配中文
- $str = 'preg_match正则匹配中文123';
- // 正则表达式匹配中文(UTF8编码)
- if(preg_match('/[\x{4e00}-\x{9fa5}]+/u',$str)){
- echo '匹配';
- }else{
- echo '没有匹配';
- }
- // 正则表达式匹配中文(GB2312,GBK编码)
- preg_match("/^[".chr(0xa1)."-".chr(0xff)."A-Za-z0-9_]+$/",$str);