URL видео YouTube может встречаться в различных форматах:
Вот функция 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>');
}
Примечания:
- Часть VIDEO_ID URL-адреса захвачена в одной-единственной группе захвата:
$1
.
- Если вы знаете, что ваш текст не содержит предварительно связанных URL-адресов, вы можете безопасно удалить отрицательное предварительное утверждение, которое проверяет это условие (утверждение, начинающееся с комментария: "URL-адрес утверждения предварительно не связан . ") Это несколько ускорит регулярное выражение.
- Строка замены может быть изменена в соответствии с требованиями. Приведенный выше просто создает ссылку на общий URL-адрес в стиле
"http://www.youtube.com/watch?v=VIDEO_ID"
и устанавливает для текста ссылки: "YouTube link: VIDEO_ID"
.
Редактировать 2011-07-05: Добавлено -
дефис для идентификатора класса char
Изменить 2011-07-17: Исправлено регулярное выражение для использования любой оставшейся части (например, запрос ) URL-адреса, следующего за идентификатором YouTube. Добавлен 'i'
ignore-case модификатор. Переименована функция в camelCase. Усовершенствованный предварительный тест на просмотр.
Редактировать 2011-07-27: Добавлены новые форматы URL-адресов YouTube для пользователей и ytscreeningroom.
Редактировать 2011-08-02: Упрощенный / обобщенный для обработки новых URL-адресов "все / что-нибудь / идет" YouTube.
Редактировать 2011-08-25: Несколько модификаций:
- Добавлена версия JavaScript:
linkifyYouTubeURLs()
функция.
- В предыдущей версии часть схемы (протокол HTTP) была необязательной и, следовательно, соответствовала бы недействительным URL-адресам. Сделана схема обязательной части.
- Предыдущая версия использовала привязку границы слова
\b
вокруг VIDEO_ID. Однако это не будет работать, если VIDEO_ID начинается или заканчивается с чертой -
. Исправлено, чтобы справиться с этим условием.
- Изменено выражение VIDEO_ID, поэтому оно должно быть ровно 11 символов.
- В предыдущей версии не удалось исключить предварительно связанные URL-адреса, если у них была строка запроса, следующая за VIDEO_ID. Исправлено негативное предположение, чтобы исправить это.
- Добавлены
+
и %
в строку запроса, соответствующую классу символов.
- Изменен разделитель регулярных выражений версии PHP с:
%
на: ~
.
- Добавлен раздел «Заметки» с некоторыми удобными заметками.
Изменить 2011-10-12: Часть хоста URL-адреса YouTube теперь может иметь любой поддомен (не только www.
).
Изменить 2012-05-01: В разделе «Использовать URL» теперь можно указывать «-».
Редактировать 2013-08-23: Добавлен дополнительный формат, предоставляемый @Mei. (Часть запроса может иметь .
точку.
Редактировать 2013-11-30: Добавлен дополнительный формат, предоставляемый @CRONUS: youtube-nocookie.com
.
Редактировать 2016-01-25: Исправлено регулярное выражение для обработки ошибки, предоставленной CRONUS.