0

我正在尝试从 html 文件中获取这些匹配项。它有几个关于它们的声明,如下所示:

links(6)  = "chicas-con-juguetes.asp"

我正在尝试使用此功能提取它们:

    public static function extract_all_vid_links($html){
    $pattern="links([0-9])  = \"(.*).asp\"";
    preg_match_all( "/$pattern/i", $html ,$out, PREG_SET_ORDER);

    print_r($out);
    //    foreach($out as $values){
    //       echo $values[0]."<br/>";
    //   }
}

但它不起作用!?!?为什么?

修改的:

    $pattern="links\([0-9]\)  = \"(.*).asp\"";
    preg_match_all( "/$pattern/i", $html ,$out, PREG_SET_ORDER);

还是不行。

4

2 回答 2

2

如果您不想创建新的匹配组,则需要转义(and字符,请看这里: .)links\(\d\)

这确实解决了您描述的问题(因此您的描述可能是错误的):

<?php
header('Content-Type: text/plain;');


$html = 'links(6)  = "chicas-con-juguetes.asp"';

$pattern="links\(\d\)  = \"(.*).asp\"";
$r = preg_match_all( "/$pattern/i", $html ,$matches);

var_dump($r, $matches);

演示,输出:

int(1)
array(2) {
  [0]=>
  array(1) {
    [0]=>
    string(37) "links(6)  = "chicas-con-juguetes.asp""
  }
  [1]=>
  array(1) {
    [0]=>
    string(19) "chicas-con-juguetes"
  }
}
于 2012-06-03T12:03:59.140 回答
1
preg_match_all('/links\([0-9]+\)  = \"([^\.]*?).asp\"/i', $html, $out, PREG_SET_ORDER);

您需要转义()字符。另外,我在后面添加了一个+[0-9]这样 9 以上的数字也可以工作。

于 2012-06-03T12:04:57.967 回答