到目前为止,我一直在使用此正则表达式代码来获取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);
}
有什么帮助吗?
答案 0 :(得分:2)
尝试这个(基于数组中的4个给定值):
/^(\[url\="){0,1}http[s]{0,1}\:\/\/(www\.){0,1}(youtube\.com|youtu\.be)\/watch\/\?v\=(.+)(\]){0,1}/ims
您将在第三组结果中获取您的ID
答案 1 :(得分:0)
试试这个,我是从这个网站上的另一个链接获得的
preg_match('#<object[^>]+>.+?http://www.youtube.com/v/([A-Za-z0-9\-_]+).+?</object>#s', $markup, $matches);
var_dump($matches[1]);