这段正则该怎么改

刚开始学正则,试着写了一个,结果报错了,我的代码是:

<?php
$content = file_get_contents('page.html');
$preg='/^<meta property="og:image" content="{1}(.*)" />{1}$/';
if(preg_match($preg,$content,$arr)){ 
echo $arr[0]; 
}else{ 
echo "fail";
}
?>

目的是要匹配到<meta property="og:image" content="https://scontent-nrt1-1.cdninstagram.com/t51.2885-15/e35/19428654_117834015492201_3447552780867207168_n.jpg" />中的地址。

阅读 2.6k
4 个回答

<?php
define('CLI_SCRIPT', true);

$content = file_get_contents('page.html');
preg_match_all('/<meta [^>]*content=\"(.+?)\"/', $content, $matches);
var_dump($matches);   // 需要的字符串在$matches[1]中,具体信息可以打印了看

你别加开始和结束符号,匹配出内容的话,不应该加开始结束符号。。。。

目测是{1}那里错了

,这个也可以。。不过很奇怪,print_r和var_dump出来的不一样

$str = '<meta property="og:image" content="https://scontent-nrt1-1.cdninstagram.com/t51.2885-15/e35/19436259_259857144497308_9134693580806291456_n.jpg" />';

$preg='/^<meta property="og:image" content="([^\"]*)"/';
if(preg_match($preg, $str, $arr)){
    echo "<pre>";

    var_dump($arr);

    print_r($arr);

    echo $arr['1'];
}else{
    echo "fail";
}
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题