信息采集循环入库,保存图片到本地,分页展示,memcache搜索判断次数,详情展示,防盗链

<?php
defined('BASEPATH') OR exit('No direct script access allowed');

class Welcome extends MY_Controller {
    public function __construct(){
        parent::__construct();
        $this->load->model('News_model',"news");
    }

    /**
     * 信息采集
     *
     * @author: BING
     */        
    public function gather(){
        //打开网页
        $url="http://news.ifeng.com/mainland/";
        $str=file_get_contents($url);
        //$str=iconv("GBK", "utf-8", $str);
        //粗略正则验证
        $reg='#<div class="juti_new">.*<div class="dianj box">#isU';
        preg_match($reg, $str, $arr);
        //var_dump($arr);
        //精确正则
        $reg1='#<div class="ju_pic"><a href=".*" target="_blank" title="(.*)"><img src="(.*)" .*></a></div>#isU';
        preg_match_all($reg1, $arr[0], $title);
        //var_dump($title);

        //精确正则
        $reg2='#<span>(.*)</span>#isU';
        preg_match_all($reg2, $arr[0], $time);
        //var_dump($time);
        
        //循环下载图片
        foreach ($title[2] as $key => $val) {
            $st=file_get_contents($val);
            $ext=substr($val, strrpos($val, "."));
            $filename="uploads/".time().rand().$ext;
            file_put_contents($filename, $st);

            //插入信息
            $data=array(
                    "title"=>$title[1][$key],
                    "img"=>$filename,
                    "time"=>$time[1][$key]
                );
            $re=$this->db->insert("news",$data);
            if ($re) {
                //最后插入id
                $in_id=$this->db->insert_id();
                //替换模板
                $str=file_get_contents("application/views/new.html");
                $str=str_replace("{title}", $data['title'], $str);
                $str=str_replace("{img}", $data['img'], $str);
                $str=str_replace("{time}", $data['time'], $str);
                //生成文件名
                $file=md5(time().$in_id).".html";
                //生成静态文件
                file_put_contents("application/cache/".$file, $str);
                //修改数据库
                $res=$this->db->where("id=$in_id")->update('news',array("action"=>$file));
                

            }else{
                echo 0;die;
            }
            

        }
        if ($res&&$re) {
            redirect('/Welcome/news_list', 'refresh');
        }
        

    }        

    //分页展示
    public function news_list(){


        //接page;         
        $page = $this->uri->segment(3,1);

        //分页的每页显示条数
        $lengh=3;

        //链接mem
        $mem=new Memcache;
        $mem->connect("127.0.0.1",11211);    

            
        if (!empty($_GET['keywords'])) {     
            $keywords=$_GET['keywords'];     

            //如果存在keywords从mem获取值
            $num=$mem->get($keywords);

            //判断次数
            if ($num) {
                $mem->set($keywords,$num+1);
                if ($num>10) {
                    //从mem中读取数组
                    $data=$mem->get('data'.$keywords);
                    if ($data) {
                        //查询新闻总数
                        $count=count($data);
                        //按照分页取出相应新闻
                        $start=($page-1)*$lengh;
                        $list=array_splice($data, $start , $lengh);
                        //var_dump($list."10");die;
                    }else{
                        $mem->set($keywords,1);
                        $count=$this->news->num($keywords);
                        $list=$this->news->select($page,$keywords);
                    }
                    

                }elseif ($num==10) {
                    $data=$this->db->like('title',$keywords)->get('news')->result_array();
                    //将查询的数据存入mem
                    $mem->set("data".$keywords,$data,false, 30*60);
                    $count=count($data);
                    $list=$this->news->select($page,$keywords);    
                    //var_dump($list."2");die;
                }else{
                    //直接从数据库读取数据
                    $count=$this->news->num($keywords);
                    $list=$this->news->select($page,$keywords);    
                    //var_dump($list."1");die;
                }
            }else{
                $mem->set($keywords,1);
                $count=$this->news->num($keywords);
                $list=$this->news->select($page,$keywords);    
                //var_dump($list."0");die;        
            }
            
            
        }else{
            $keywords='';            
            $count=$this->news->total_num($keywords);
            $list=$this->news->select($page,$keywords);        
        }



        //分页         
        $pages=ceil($count/$lengh);         
        $prev=$page<=1?1:$page-1;
        $next=$page>=$pages?$pages:$page+1;    
        $url=base_url()."Welcome/news_list";
        $links='<a href="'.$url.'/1.html?keywords='.$keywords.'">首页</a><a href="'.$url.'/'.$prev.'.html?keywords='.$keywords.'">上一页</a><a href="'.$url.'/'.$next.'.html?keywords='.$keywords.'">下一页</a><a href="'.$url.'/'.$pages.'.html?keywords='.$keywords.'">尾页</a>';

        
        $this->load->vars('list',$list);
        $this->load->vars('keywords',$keywords);
        $this->load->vars('page',$links);
        $this->load->view("list.html");
    }    

    //详情展示
    public function news(){

        //$id=$_GET['id'];
        $id = $this->uri->segment(3,1);
        $re=$this->db->where("id=$id")->get('news')->row_array();

         $str=file_get_contents("application/cache/".$re['action']);
         echo "yes".$str;

    }    

    //防盗链
    public function error(){
        header("content-type:text/html;charset=utf8");
        $str=file_get_contents("http://hao.360.cn/?360sd");
        //$str=iconv("GBK", "utf8", $str);
        $this->load->vars('str',$str);
        $this->load->view('error.html');

    }


    
}    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在信号处理领域,DOA(Direction of Arrival)估计是一项关键技术,主要用于确定多个信号源到达接收阵列的方向。本文将详细探讨三种ESPRIT(Estimation of Signal Parameters via Rotational Invariance Techniques)算法在DOA估计中的实现,以及它们在MATLAB环境中的具体应用。 ESPRIT算法是由Paul Kailath等人于1986年提出的,其核心思想是利用阵列数据的旋转不变性来估计信号源的角度。这种算法相比传统的 MUSIC(Multiple Signal Classification)算法具有较低的计算复杂度,且无需进行特征值分解,因此在实际应用中颇具优势。 1. 普通ESPRIT算法 普通ESPRIT算法分为两个主要步骤:构造等效旋转不变系统和估计角度。通过空间平移(如延时)构建两个子阵列,使得它们之间的关系具有旋转不变性。然后,通过对子阵列数据进行最小二乘拟合,可以得到信号源的角频率估计,进一步转换为DOA估计。 2. 常规ESPRIT算法实现 在描述中提到的`common_esprit_method1.m`和`common_esprit_method2.m`是两种不同的普通ESPRIT算法实现。它们可能在实现细节上略有差异,比如选择子阵列的方式、参数估计的策略等。MATLAB代码通常会包含预处理步骤(如数据归一化)、子阵列构造、旋转不变性矩阵的建立、最小二乘估计等部分。通过运行这两个文件,可以比较它们在估计精度和计算效率上的异同。 3. TLS_ESPRIT算法 TLS(Total Least Squares)ESPRIT是对普通ESPRIT的优化,它考虑了数据噪声的影响,提高了估计的稳健性。在TLS_ESPRIT算法中,不假设数据噪声是高斯白噪声,而是采用总最小二乘准则来拟合数据。这使得算法在噪声环境下表现更优。`TLS_esprit.m`文件应该包含了TLS_ESPRIT算法的完整实现,包括TLS估计的步骤和旋转不变性矩阵的改进处理。 在实际应用中,选择合适的ESPRIT变体取决于系统条件,例如噪声水平、信号质量以及计算资源。通过MATLAB实现,研究者和工程师可以方便地比较不同算法的效果,并根据需要进行调整和优化。同时,这些代码也为教学和学习DOA估计提供了一个直观的平台,有助于深入理解ESPRIT算法的工作原理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值