• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

如何通过php 获取页面中的指定内容类

php 搞代码 3年前 (2022-01-22) 28次浏览 已收录 0个评论

功能:

1.获取内容中的url,email,image。

2.替换内容中的url,email,image。

url:<a href="url">xxx</a>

email:[email protected]

image:<img src="image">

Grep.class.php

<?php/** grep class*   Date:   2013-06-15*   Author: fdipzone*   Ver:    1.0**   Func:**   set:        设置内容*   get:        返回指定的内容*   replace:    返回替换后的内容*   get_pattern 根据type返回pattern*/class Grep{ // class start    private $_pattern = array(                            'url' => '/<a.*?href="((http(s)?:\/\/).*?)".*?/si',                            'email' => '/([\w\-\.]+@[\w\-\.]+(\.\w+))/',                            'image' => '/<img.*?src=\"(http:\/\/.+\.(jpg|jpeg|gif|bmp|png))\">/i'                        );    private $_content = ''; // 源内容    /* 設置搜尋的內容    *  @param String $content    */    public function set($content=''){        $this->_content = $content;    }    /* 获取指定内容    *  @param String $type    *  @param int    $unique 0:all 1:unique    *  @return Array    */    public function get($type='', $unique=0){        $type = strtolower($type);        if($this->_content=='' || !in_array($type, array_keys($this->_pattern))){            return array();        }        $pattern = $this->get_pattern($type); // 获取pattern        preg_match_all($pattern, $this->_content, $matches);        return isset($matches[1])? ( $unique==0? $matches[1] : array_unique($matches[1]) ) : array();    }    /* 获取替换后的内容    *  @param String $type    *  @param String $callback    *  @return String    */    public function replace($type='', $callback=''){        $type = strtolower($type);        if($this->_content=='' || !in_array($type, array_keys($this->_pattern)) || $callback==''){            return $this->_content;        }        $pattern = $this->get_pattern($type);        return preg_replace_callback($pattern, $callback, $this->_content);    }    /* 根据type获取pattern    *  @param String $type    *  @return String    */    private function get_pattern($type){        return $this->_pattern[$type];    }} // class end?>

Demo

<?phpheader('content-type:text/htm;charset=utf8');require('Grep.class.php');$content = file_get_cont<div style="color:transparent">本&文来源gaodai^.ma#com搞#代!码网</div><strong>搞gaodaima代码</strong>ents('http://www.test.com/');$obj = new Grep();$obj->set($content);$url = $obj->get('url', 0);$email = $obj->get('email', 1);$image = $obj->get('image', 1);print_r($url);print_r($email);print_r($image);$url_new = $obj->replace('url', 'replace_url');echo $url_new;function replace_url($matches){    return isset($matches[1])? '[url]'.$matches[1].'[/url]' : '';}?>

本文讲解了如何通过php 获取页面中的指定内容类 ,更多相关内容请随时关注我们网站!

相关推荐:

介绍php相关语法技巧

如何通过php 根据url自动生成缩略图

介绍php output_buffering 缓存使用的方法

以上就是如何通过php 获取页面中的指定内容类的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:如何通过php 获取页面中的指定内容类
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址