6、正则表达式

6、正则表达式_第1张图片

模式修正符:i 忽略大小写 g 全局匹配


6、正则表达式_第2张图片

特别字符

6、正则表达式_第3张图片

6、正则表达式_第4张图片

6、正则表达式_第5张图片

比较重要的两个方面:


preg_replace — 执行一个正则表达式的搜索和替换,搜索subject中匹配pattern的部分, 以replacement进行替换。
preg_replace ( pattern ,replacement , $subject )

返回值:

如果subject是一个数组, preg_replace()返回一个数组, 其他情况下返回一个字符串。
如果匹配被查找到,替换后的subject被返回,其他情况下 返回没有改变的 subject。如果发生错误,返回 NULL 。

6、正则表达式_第6张图片
后向引用

关于php的贪婪模式详解

 .*  是贪婪模式     .*?   取消贪婪模式。
6、正则表达式_第7张图片
贪婪模式
6、正则表达式_第8张图片
用?取消贪婪

6、正则表达式_第9张图片
大U取消贪婪




preg_match():preg_match — 执行一个正则表达式匹配

int preg_match( string pattern, string subject [, array matches ] )
pattern:正则表达式
subject:需要匹配检索的对象
matches:可选,存储匹配结果的数组, $matches[0] 将包含与整个模式匹配的文本,$matches[1] 将包含与第一个捕获的括号中的子模式所匹配的文本,以此类推

preg_match_all() 函数用于进行正则表达式全局匹配,成功返回整个模式匹配的次数(可能为零),如果出错返回 FALSE 。
preg_replace — 执行一个正则表达式的搜索和替换

preg_match() 返回 pattern 所匹配的次数。要么是 0 次(没有匹配)或 1 次,因为 preg_match() 在第一次匹配之后将停止搜索。preg_match_all() 则相反,会一直搜索到 subject 的结尾处。如果出错 preg_match() 返回 FALSE。

mixed preg_replace ( mixed $pattern , mixed $replacement , mixed $subject [, int $limit = -1 [, int &$count ]] )
搜索subject中匹配pattern的部分, 以replacement进行替换。

preg_split — 通过一个正则表达式分隔字符串

array preg_split  ( string $pattern  , string $subject  [, int $limit  = -1  [, int $flags  = 0  ]] )
eg:
 
输出:
Array
(
    [0] => hypertext
    [1] => language
    [2] => programming
)
6、正则表达式_第10张图片
6、正则表达式_第11张图片
匹配中文的实例
匹配到了中文
6、正则表达式_第12张图片
6、正则表达式_第13张图片
6、正则表达式_第14张图片
6、正则表达式_第15张图片

6、正则表达式_第16张图片
匹配单引号或双引号
.*?a
就是取前面任意长度的字符,到底一个 a 出现,匹配如下
q@wer_qwerqweraljlkjlkjlkj
得到:q@wer_qwerqwera 这部分,如果匹配不到后面的 a 字符,则匹配为空。

匹配URL:

邮箱:

6、正则表达式_第17张图片

ip地址:

//匹配ip地址:
$str = "192.56.20.253";
$pattern = '/^([1-9]|[1-9]\d|1\d\d|2[01]\d|22[0-3])(\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])){3}$/';
preg_match($pattern,$str,$match);
print_r($match);

6、正则表达式_第18张图片

参考github

你可能感兴趣的:(6、正则表达式)