关于本站
“最难不过坚持”
本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作
有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339
2655
39
分类目录
最新评论
- https://jueru.net/
-
- :weixiao:
-
- :shuijiao: :weiqu: :zhenbang: :leng:
-
- :yiwen: :yiwen: :yiwen: :yiwen:
-
- 这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
-
文章标签更多
打开边栏(ESC)
关闭边栏(ESC)
preg_match()执行匹配正则表达式
说明
preg_match ( string $pattern , string $subject [, array &$matches [, int $flags = 0 [, int $offset = 0 ]]] ) : int搜索subject与pattern给定的正则表达式的一个匹配.
参数
pattern
要搜索的模式,字符串类型。
subject
输入字符串。
matches
如果提供了参数matches,它将被填充为搜索结果。 $matches[0]将包含完整模式匹配到的文本, $matches[1] 将包含第一个捕获子组匹配到的文本,以此类推。
flags(示例五)
flags可以被设置为以下标记值:
PREG_OFFSET_CAPTURE
如果传递了这个标记,对于每一个出现的匹配返回时会附加字符串偏移量(相对于目标字符串的)。 注意:这会改变填充到matches参数的数组,使其每个元素成为一个由 第0个元素是匹配到的字符串,第1个元素是该匹配字符串 在目标字符串subject中的偏移量。
offset(示例六)
通常,搜索从目标字符串的开始位置开始。可选参数 offset 用于 指定从目标字符串的某个位置开始搜索(单位是字节)。
返回值
preg_match()返回 pattern 的匹配次数。 它的值将是0次(不匹配)或1次,因为preg_match()在第一次匹配后 将会停止搜索。preg_match_all()不同于此,它会一直搜索subject 直到到达结尾。 如果发生错误preg_match()返回 FALSE。
示例一:查找文本字符串"php"
<?php //模式分隔符后的"i"标记这是一个大小写不敏感的搜索 if (preg_match("/php/i", "PHP is the web scripting language of choice.")) { echo "匹配"; } else { echo "不匹配"; } // 匹配 ?>示例二:查找单词"web"
<?php /* 模式中的\b标记一个单词边界,所以只有独立的单词"web"会被匹配,而不会匹配单词的部分内容比如"webbing" 或 "cobweb" */ if (preg_match("/\bweb\b/i", "PHP is the web scripting language of choice.")) { echo "匹配"; } else { echo "不匹配"; } echo '<hr>'; if (preg_match("/\bweb\b/i", "PHP is the website scripting language of choice.")) { echo "匹配"; } else { echo "不匹配"; } ?>示例三:获取URL中的域名
<?php //从URL中获取主机名称 preg_match('@^(?:http://)?([^/]+)@i',"http://www.php.net/index.html", $matches); $host = $matches[1]; echo $host . '<br>'; // www.php.net //获取主机名称的后面两部分 preg_match('/[^.]+\.[^.]+$/', $host, $matches); echo "域名: {$matches[0]}"; // 域名: php.net ?>示例四:使用命名子组
<?php $str = 'foobar: 2008'; preg_match('/(?P<name>\w+): (?P<digit>\d+)/', $str, $matches); /* 下面例子在php 5.2.2(pcre 7.0)或更新版本下工作, 然而, 为了后向兼容, 上面的方式是推荐写法. */ // preg_match('/(?<name>\w+): (?<digit>\d+)/', $str, $matches); var_dump($matches); // array (size=5) // 0 => string 'foobar: 2008' (length=12) // 'name' => string 'foobar' (length=6) // 1 => string 'foobar' (length=6) // 'digit' => string '2008' (length=4) // 2 => string '2008' (length=4) ?>示例五:flags可以被设置为以下标记值:PREG_OFFSET_CAPTURE
<?php preg_match('/(foo)(bar)(baz)/', 'foobarbaz', $matches, PREG_OFFSET_CAPTURE); var_dump($matches); // array (size=4) // 0 => // array (size=2) // 0 => string 'foobarbaz' (length=9) // 1 => int 0 // 1 => // array (size=2) // 0 => string 'foo' (length=3) // 1 => int 0 // 2 => // array (size=2) // 0 => string 'bar' (length=3) // 1 => int 3 // 3 => // array (size=2) // 0 => string 'baz' (length=3) // 1 => int 6 echo '<br>对比没有参数PREG_OFFSET_CAPTURE<br>'; preg_match('/(foo)(bar)(baz)/', 'foobarbaz', $matches); var_dump($matches); // array (size=4) // 0 => string 'foobarbaz' (length=9) // 1 => string 'foo' (length=3) // 2 => string 'bar' (length=3) // 3 => string 'baz' (length=3) ?>示例六:可选参数 offset 用于 指定从目标字符串的某个位置开始搜索
<?php $subject = "abcdef"; $pattern = '/def/'; preg_match($pattern, $subject, $matches, PREG_OFFSET_CAPTURE, 4); // 从字符串位置4开始匹配,即从e开始。注释:字符串位置从 0 开始,不是从 1 开始。 print_r($matches); // Array ( ) echo '<br>对比没有设置offset参数<br>'; preg_match($pattern, $subject, $matches, PREG_OFFSET_CAPTURE); print_r($matches); // Array ( [0] => Array ( [0] => def [1] => 3 ) ) ?>
赏
相关推荐
php实现ZIP压缩文件解压缩,中文乱码解决方法(重要)
直接上代码,具体代码里面都有注释。直接中文压缩文件解压到中文文件夹。
<?php
// 需开启配置 php_zip.dll
// phpinfo();
header("Content-type:text/html;charset=utf-8");
/*
* $filename 被解压文件名
* $path 解压...
openssl_private_decrypt解密失败
复制别人的解密程序,原程序可以解密,复制过来就不可以
一步步尝试发现,秘钥换行符有区别,
原秘钥有换行符,复制过来不知道什么时候把换行符清空了,成了一行字符串了。
评论加载中...
前一篇: PHP约瑟夫小游戏的代码
后一篇: PHP 正则表达式的使用