php匹配指定标签的内容

php匹配指定div内容,在用php编写采集程序的时候,抓取到的网页数据有时候我们只需要一小段标签内容,怎么才能冲html代码中提取出来呢,这里提供一个函数示例,实现php匹配任意html标签内的所有内容:

站在用户的角度思考问题,与客户深入沟通,找到桂东网站设计与桂东网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站建设、网站设计、企业官网、英文网站、手机端网站、网站推广、域名注册、虚拟空间、企业邮箱。业务覆盖桂东地区。

/**
* 匹配任意id的html标签内容
* 
*/
function getWebTag($tag_id,$tag='div',$data=false){     
        $charset_pos = stripos($data,'charset');
        if($charset_pos) {
            if(stripos($data,'utf-8',$charset_pos)) {
                $data = iconv('utf-8','utf-8',$data);
            }else if(stripos($data,'gb2312',$charset_pos)) {
                $data = iconv('gb2312','utf-8',$data);
            }else if(stripos($data,'gbk',$charset_pos)) {
                $data = iconv('gbk','utf-8',$data);
            }
        }
       
        preg_match_all('/<'.$tag.'/i',$data,$pre_matches,PREG_OFFSET_CAPTURE);    //获取所有div前缀
        preg_match_all('/<\/'.$tag.'/i',$data,$suf_matches,PREG_OFFSET_CAPTURE); //获取所有div后缀
        $hit = strpos($data,$tag_id);
        if($hit == -1) return false;    //未命中
        $divs = array();    //合并所有div
        foreach($pre_matches[0] as $index=>$pre_div){
            $divs[(int)$pre_div[1]] = 'p';
            $divs[(int)$suf_matches[0][$index][1]] = 's';   
        }
       
        //对div进行排序
        $sort = array_keys($divs);
        asort($sort);
       
        $count = count($pre_matches[0]);
        foreach($pre_matches[0] as $index=>$pre_div){
            //';
                break;
            }
        }
        return $hitDivString;
}

调用示例

$html=file_get_contents('http://www.baidu.com');

$divContent=getWebTag('id="content"','div',$html);


网站名称:php匹配指定标签的内容
当前URL:http://bzwzjz.com/article/ijdpje.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都企业网站建设公司 成都网站建设 手机网站建设 手机网站设计 高端网站设计推广 高端品牌网站建设 教育网站设计方案 品牌网站建设 成都定制网站建设 成都响应式网站建设 四川成都网站建设 定制网站设计 网站建设开发 成都网站制作 网站建设费用 梓潼网站设计 阿坝网站设计 成都网站制作 网站制作 app网站建设 重庆企业网站建设 成都网站设计