YouTube動画のURLは、さまざまな形式で発生する可能性があります。
- 最新の短い形式:
http://youtu.be/NLqAF9hrVbY
- iframe:
http://www.youtube.com/embed/NLqAF9hrVbY
- iframe(セキュア):
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
- ytscreeningroom:
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
- nocookieドメイン:
http://www.youtube-nocookie.com
以下は、これらの各URLフォームに一致し、リンクに変換するコメント付きの正規表現を持つPHP関数です(まだリンクでない場合)。
// 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>');
}
ノート:
- URLのVIDEO_ID部分は、唯一のキャプチャグループでキャプチャされます
$1
。
- テキストに事前にリンクされたURLが含まれていないことがわかっている場合は、この条件をテストする否定先読みアサーション(コメントで始まるアサーション:「URLが事前にリンクされていない」)を安全に削除できます。正規表現を少し上げます。
- 置換文字列は、必要に応じて変更できます。上記のコードは、一般的な
"http://www.youtube.com/watch?v=VIDEO_ID"
スタイルのURL へのリンクを作成し、リンクテキストを次のように設定するだけです"YouTube link: VIDEO_ID"
。
2011-07-05を編集:-
ID文字クラスにハイフンを追加
編集2011-07-17: YouTube IDに続くURLの残りの部分(クエリなど)を消費するように正規表現を修正しました。'i'
ignore-case修飾子を追加しました。関数の名前をcamelCaseに変更しました。事前リンク先読みテストの改善。
2011-07-27を編集: YouTube URLの新しい「ユーザー」および「ytscreeningroom」形式を追加しました。
2011-08-02を編集:新しい「any / thing / goes」YouTube URLを処理するために簡略化/一般化。
2011-08-25を編集:いくつかの変更:
- Javascriptバージョンの追加:
linkifyYouTubeURLs()
関数。
- 以前のバージョンでは、スキーム(HTTPプロトコル)の部分はオプションだったため、無効なURLに一致していました。スキーム部分を必須にしました。
- 以前のバージョンで
\b
は、VIDEO_IDの周囲に単語境界アンカーが使用されていました。ただし、VIDEO_IDが-
ダッシュで始まっているか、ダッシュで終わっている場合、これは機能しません。この状態を処理するように修正されました。
- 正確に11文字になるようにVIDEO_ID式を変更しました。
- 以前のバージョンでは、VIDEO_IDの後にクエリ文字列が含まれている場合、事前にリンクされたURLを除外できませんでした。これを修正するために否定先読みアサーションを改善しました。
+
と%
文字クラスマッチングクエリ文字列に追加されました。
- PHPバージョンの正規表現区切り文字を:
%
からa:に変更しました~
。
- いくつかの便利なメモを含む「メモ」セクションを追加しました。
2011-10-12を編集: YouTube URLホストパーツにサブドメイン(だけではなくwww.
)が含まれるようになりました。
編集2012-05-01: URLの消費セクションで「-」を使用できるようになりました。
2013-08-23を編集: @Meiが提供する追加のフォーマットを追加しました。(クエリ部分に.
ドットが含まれる場合があります。
2013-11-30を編集: @CRONUSによって提供される追加のフォーマットを追加:youtube-nocookie.com
。
2016-01-25を編集: CRONUSが提供するエラーケースを処理するように正規表現を修正しました。