我有一个文本字段,用户可以在其中编写任何内容。
现在,我想解析它并找到所有YouTube视频URL及其ID。
任何想法如何工作?
YouTube视频网址可能会以多种格式出现:
http://youtu.be/NLqAF9hrVbY
http://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
http://www.youtube.com/watch?v=NLqAF9hrVbY
http://www.youtube.com/user/Scobleizer#p/u/1/1p3vcRhsYGo
http://www.youtube.com/ytscreeningroom?v=NRHVzbJVx8I
http://www.youtube.com/sandalsResorts#p/c/54B8C800269D7C1B/2/PPS-8DMrAn4
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=youtu.be
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,
[^\w\s-] # 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)?\.com\S*?[^\w\s-])([\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"
样式URL的链接,并将链接文本设置为:"YouTube link: VIDEO_ID"
。编辑2011-07-05:-
在ID字符类中添加了连字符
编辑2011-07-17: 修复了正则表达式以使用YouTube ID后占用URL的任何其余部分(例如 query )的问题。添加了'i'
忽略大小写 修饰符。将函数重命名为camelCase。改进的预链接超前测试。
编辑2011-07-27: 添加了YouTube URL的新“用户”和“ ytscreeningroom”格式。
编辑2011-08-02: 简化/通用化以处理新的“任意/全部/正常” YouTube URL。
编辑2011-08-25:进行了 一些修改:
linkifyYouTubeURLs()
函数:。\b
在VIDEO_ID周围使用了字边界锚。但是,如果VIDEO_ID以-
破折号开头或结尾,则此操作将无效。已修复,使其可以处理此情况。+
和%
。%
到:~
。编辑2011-10-12: YouTube URL主机部分现在可以具有任何子域(而不仅仅是www.
)。
编辑2012-05-01: 消费URL部分现在可以使用’-‘。
编辑2013-08-23: 添加了@Mei提供的其他格式。(查询部分可能有一个.
点。
编辑2013-11-30: 添加了@CRONUS提供的其他格式:youtube-nocookie.com
。
编辑 2016年1月25日 : 修复了正则表达式以处理CRONUS提供的错误情况。
问题内容: 我试图返回一个数组或切片,针对字符串针对特定正则表达式的所有匹配项。字符串是: 我想返回一个花括号之间所有字符串都匹配的数组。我尝试使用regexp软件包来完成此操作,但无法弄清楚如何返回我要查找的内容。这是我当前的代码: 但是,无论我尝试什么,每次返回的结果都是一片空白。 问题答案: 首先,您不需要正则表达式定界符。其次,使用原始字符串文字定义一个正则表达式模式是个好主意,您只需要使
问题内容: 我想用以下代码查找字符串中的所有数字: 我还尝试将定界符添加到正则表达式,使用正数作为的第二个参数,使用仅数字字符串,例如“ 123”作为第一个参数… 但是输出总是 我似乎想念一下正则表达式在Go中的工作原理,但是无法绕开它。这不是有效的表达方式吗? 问题答案: 问题出在你的第二个整数参数上。引用以下软件包的文档: 这些例程使用一个额外的整数参数n;如果n> = 0,则该函数最多返回n
本文向大家介绍PHP 正则表达式获得YouTube视频ID,包括了PHP 正则表达式获得YouTube视频ID的使用技巧和注意事项,需要的朋友参考一下 parse_url和parse_str函数可用于获取特定YouTube视频的ID。 示例 输出结果 在上面的代码中,parse_url函数接收一个字符串并将其切成一个信息数组。可以将用户特别希望使用的元素指定为第二个参数,也可以使用整个数组。 Yo
本文向大家介绍PowerShell使用正则表达式查找字符串实例,包括了PowerShell使用正则表达式查找字符串实例的使用技巧和注意事项,需要的朋友参考一下 本文介绍在PowerShell中使用-match运算符加正则表达式,进行字符串的搜索。 match运算符,后面加上正则表达式,可以对字符串进行正则匹配查找。正则表达式功能强大,用于查找字符串时方便快捷。所以match运算符是我们经常要用到的
问题内容: 我正在创建一个类,该类使用用户指定的格式重命名文件。这种格式将是一个简单的字符串,将调用其方法来填充空格。 事实证明,我的过程将需要提取花括号中包含的变量名称。例如,一个字符串可能包含,应该产生yield 。当然,单个字符串中会有几组花括号,我需要按它们出现的顺序获取它们的内容,并将它们输出到列表中。 因此,应屈服。 我怀疑最简单的方法是使用,但是我对正则表达式一无所知。有人可以帮我吗
问题内容: 如果我有这样的字符串: 我需要一种从字符串中获取“ BAR”字符串的通用方法,以便无论方括号之间是什么字符串,都可以获取该字符串。 例如 问题答案: 你应该能够使用非贪婪的量词,特别是*?。你可能需要以下条件: 这将为你提供一个与你的字符串匹配的模式,并将文本放在第一组的方括号内。请查看Pattern API文档以获取更多信息。 要提取字符串,可以使用如下所示的内容: