0

到目前为止,我一直在使用这个正则表达式代码来获取 YouTube 视频的 ID

"/https?:\/\/w*.?(?:youtube.com|youtu.be)\/watch\/\?v=([A-Za-z0-9\-_]+)/i"

我尝试扩展它,所以它会忽略 HTML 链接中 YouTube 视频的 ID (href="..")

"/[?:(^href=\")]https?:\/\/w*.?(?:youtube.com|youtu.be)\/watch\/\?v=([A-Za-z0-9\-_]+)/i"

不幸的是,那不是这样做的。事实上,完整的代码会产生相反的结果。

$input = array(
    'http://youtube.com/watch/?v=oKay1',
    'http://youtu.be/watch/?v=oKay2',
    'href="http://youtube.com/watch/?v=NICHToKay"', //this shouldn't be found
    '[url="http://youtube.com/watch/?v=oKay3]'
    );

$pattern = "/[?:(^href=\")]https?:\/\/w*.?(?:youtube.com|youtu.be)\/watch\/\?v=([A-Za-z0-9\-_]+)/i";

foreach($input as $v) {
    $match = preg_match_all($pattern, $v, $result);
    print "$v => $match\n";
    if ($match == 1)
        var_dump($result);
}

请问有什么帮助吗?

4

2 回答 2

2

try this (based on your 4 given values in the arrays):

/^(\[url\="){0,1}http[s]{0,1}\:\/\/(www\.){0,1}(youtube\.com|youtu\.be)\/watch\/\?v\=(.+)(\]){0,1}/ims

you will get your ID in 3rd array of results

于 2013-04-23T13:44:41.797 回答
0

试试这个,我是从这个网站上的另一个链接得到的

preg_match('#<object[^>]+>.+?http://www.youtube.com/v/([A-Za-z0-9\-_]+).+?</object>#s', $markup, $matches);

var_dump($matches[1]);

来源:使用 PHP 从 html 代码中获取 Youtube 视频 ID

于 2013-04-23T13:48:19.477 回答