如何使用正则表达式查找字符串中的所有YouTube视频ID?
我有一个用户可以写任何东西的文本框。
例如:
Lorem Ipsum简直就是虚拟文本。 http://www.youtube.com/watch?v=DUQi_R4SgWo印刷和排版行业。 Lorem Ipsum自从16世纪以来一直是业界标准的虚拟文本,当时一台未知的打印机采用了一种类型的厨房,并将其制作成样本书。 它不仅存活了五个世纪,而且还实现了电子排版的飞跃,基本保持不变。 http://www.youtube.com/watch?v=A_6gNZCkajU&feature=relmfu它在20世纪60年代随着包含Lorem Ipsum段落的Letraset表单的发布以及最近使用桌面出版软件(如Aldus PageMaker,包括Lorem Ipsum版本)而得到推广。
现在我想解析它并查找所有YouTube视频网址和它们的ID。
任何想法如何工作?
YouTube视频网址可能会遇到各种格式:
http://youtu.be/NLqAF9hrVbY
http://www.youtube.com/embed/NLqAF9hrVbY
: http://www.youtube.com/embed/NLqAF9hrVbY
https://www.youtube.com/embed/NLqAF9hrVbY
: https://www.youtube.com/embed/NLqAF9hrVbY
http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
: http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
fs=1& http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
zh_CN http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
: http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
fs=1& http://www.youtube.com/v/NLqAF9hrVbY?fs=1&hl=en_US
http://www.youtube.com/watch?v=NLqAF9hrVbY
: http://www.youtube.com/watch?v=NLqAF9hrVbY
http://www.youtube.com/user/Scobleizer#p/u/1/1p3vcRhsYGo
: http://www.youtube.com/user/Scobleizer#p/u/1/1p3vcRhsYGo
http://www.youtube.com/ytscreeningroom?v=NRHVzbJVx8I
: http://www.youtube.com/ytscreeningroom?v=NRHVzbJVx8I
v http://www.youtube.com/ytscreeningroom?v=NRHVzbJVx8I
NRHVzbJVx8I http://www.youtube.com/sandalsResorts#p/c/54B8C800269D7C1B/2/PPS-8DMrAn4
: http://www.youtube.com/sandalsResorts#p/c/54B8C800269D7C1B/2/PPS-8DMrAn4
http://gdata.youtube.com/feeds/api/videos/NLqAF9hrVbY
: http://gdata.youtube.com/feeds/api/videos/NLqAF9hrVbY
http://www.youtube.com/watch?v=spDj54kf-vY&feature=g-vrec
: http://www.youtube.com/watch?v=spDj54kf-vY&feature=g-vrec
spDj54kf-vY&feature http://www.youtube.com/watch?v=spDj54kf-vY&feature=g-vrec
g-vrec http://www.youtube.com/watch?v=spDj54kf-vY&feature=youtu.be
: http://www.youtube.com/watch?v=spDj54kf-vY&feature=youtu.be
spDj54kf-vY&feature= http://www.youtube.com/watch?v=spDj54kf-vY&feature=youtu.be
http://www.youtube-nocookie.com
: http://www.youtube-nocookie.com
这是一个带有注释正则表达式的PHP函数,它匹配每个URL表单并将它们转换为链接(如果它们不是链接):
// Linkify youtube URLs which are not already links.
function linkifyYouTubeURLs($text) {
$text = preg_replace('~(?#!js YouTubeId Rev:20160125_1800)
# Match non-linked youtube URL in the wild. (Rev:20130823)
https?:// # Required scheme. Either http or https.
(?:[0-9A-Z-]+.)? # Optional subdomain.
(?: # Group host alternatives.
youtu.be/ # Either youtu.be,
| youtube # or youtube.com or
(?:-nocookie)? # youtube-nocookie.com
.com # followed by
S*? # Allow anything up to VIDEO_ID,
[^ws-] # but char before ID is non-ID char.
) # End host alternatives.
([w-]{11}) # $1: VIDEO_ID is exactly 11 chars.
(?=[^w-]|$) # Assert next char is non-ID or EOS.
(?! # Assert URL is not pre-linked.
[?=&+%w.-]* # Allow URL (query) remainder.
(?: # Group pre-linked alternatives.
['"][^<>]*> # Either inside a start tag,
| </a> # or inside <a> element text contents.
) # End recognized pre-linked alts.
) # End negative lookahead assertion.
[?=&+%w.-]* # Consume any URL (query) remainder.
~ix', '<a href="http://www.youtube.com/watch?v=$1">YouTube link: $1</a>',
$text);
return $text;
}
; //结束$ YouTubeId。
这里是一个与完全相同的正则表达式的JavaScript版本(删除了注释):
// Linkify youtube URLs which are not already links.
function linkifyYouTubeURLs(text) {
var re = /https?://(?:[0-9A-Z-]+.)?(?:youtu.be/|youtube(?:-nocookie)?.comS*?[^ws-])([w-]{11})(?=[^w-]|$)(?![?=&+%w.-]*(?:['"][^<>]*>|</a>))[?=&+%w.-]*/ig;
return text.replace(re,
'<a href="http://www.youtube.com/watch?v=$1">YouTube link: $1</a>');
}
笔记:
$1
。 "http://www.youtube.com/watch?v=VIDEO_ID"
样式网址,并将链接文本设置为: "YouTube link: VIDEO_ID"
。 编辑2011-07-05:添加-
连字符ID char类
编辑2011-07-17:修正了正则表达式消耗YouTube ID之后的URL的任何剩余部分(例如查询)。 添加了'i'
忽略大小写修饰符。 将函数重命名为camelCase。 改进的预先链接的前瞻性测试。
编辑2011-07-27:增加了新的“用户”和“ytscreeningroom”格式的YouTube网址。
编辑2011-08-02:简化/泛化处理新的“任何/事物/去”YouTube网址。
编辑2011-08-25:几个修改:
linkifyYouTubeURLs()
函数。 b
字边界锚。 但是,如果VIDEO_ID以-
破折号开始或结束,则这不起作用。 固定,以便它处理这种情况。 +
和%
。 %
更改为a: ~
。 编辑2011-10-12: YouTube URL主机部分现在可能有任何子域名(不仅仅是www.
)。
编辑2012-05-01:消耗URL部分现在可以允许' - '。
编辑2013-08-23:增加@Mei提供的其他格式。 (查询部分可能有一个.
点。
编辑2013-11-30:增加@ youtube-nocookie.com
提供的其他格式: youtube-nocookie.com
。
编辑2016-01-25:修正了正则表达式来处理CRONUS提供的错误情况。
这是我曾经为提取YouTube和Vimeo视频密钥的项目撰写的一种方法:
/**
* strip important information out of any video link
*
* @param string link to a video on the hosters page
* @return mixed FALSE on failure, array on success
*/
function getHostInfo ($vid_link)
{
// YouTube get video id
if (strpos($vid_link, 'youtu'))
{
// Regular links
if (preg_match('/(?<=v=)([wd-_]+)/', $vid_link, $matches))
return array('host_name' => 'youtube', 'original_key' => $matches[0]);
// Ajax hash tag links
else if (preg_match('§([dw-_]+)$§i', $vid_link, $matches))
return array('host_name' => 'youtube', 'original_key' => $matches[0]);
else
return FALSE;
}
// Vimeo get video id
elseif (strpos($vid_link, 'vimeo'))
{
if (preg_match('§(?<=/)([d]+)§', $vid_link, $matches))
return array('host_name' => 'vimeo', 'original_key' => $matches[0]);
else
return FALSE;
}
else
return FALSE;
}
尽管ridgerunner的回答是我回答的基础,但由于YouTube网址中有多个可能的VIDEO_ID
匹配项,所以他不能解决所有网址问题,我也不相信这是有能力的。 我的正则表达式包括他作为最后手段的侵略性方法,但首先尝试所有常见匹配,这大大减少了URL后面错误匹配的可能性。
这个正则表达式:
/https?://(?:[0-9A-Z-]+.)?(?:youtu.be/|youtube.com(?:/embed/|/v/|/watch?v=|/ytscreeningroom?v=|/feeds/api/videos/|/userS*[^w-s]|S*[^w-s]))([w-]{11})[?=&+%w-]*/ig;
处理ridgerunners示例中最初引用的所有案例,以及可能在URL中稍后有11个字符序列的任何url。 即:
http://www.youtube.com/watch?v=GUEZCxBcM78&feature=pyv&feature=pyv&ad=10059374899&kw=%2Bwingsuit
以下是一个可以测试所有示例YouTube网址的工作示例:
http://jsfiddle.net/DJSwc/5/
链接地址: http://www.djcxy.com/p/28921.html上一篇: How do I find all YouTube video ids in a string using a regex?
下一篇: Extract parameter value from url using regular expressions