|
|
|
| Вот регулярное выражение:
/[^\[url=]http:\/\/(\S+)[^\[\/url\]]/i
|
Как мне кажется оно должно означать строку, которая начинается с http:// потом идут любые символы, при этом непосредственно перед этой строкой не может идити подстрока [url= и она не может заканчиваться на [/url]
Я прав? Сразу скажу, что оно не работает должным образом... где ошибка7 | |
|
|
|
|
|
|
|
для: devil943
(08.01.2008 в 21:07)
| | А как Вы хотите чтобы это работало?
Пример того что Вам надо приведете? | |
|
|
|
|
|
|
|
для: Faraon
(08.01.2008 в 21:28)
| | Пожалуйста:
должно обработаться скриптом в [ url= http://www.yandex.ru/]http://www.yandex.ru/[/url]
а
[ url= http://www.yandex.ru/]http://www.yandex.ru/[/url]
| не должно обрабатываться.
Пробелы, что бы ссылками не стали )
Полный скрипт такой:
$patern = "/[^\[url=]http:\/\/(\S+)[^\[\/url\]]/i";
$replacment = '[ url=http://$1]http://$1[/url]';
$text = preg_replace($patern, $replacment, $text);
|
| |
|
|
|
|
|
|
|
для: devil943
(08.01.2008 в 21:32)
| | - | |
|
|
|
|
|
|
|
для: ddhvvn
(08.01.2008 в 21:34)
| | - )) | |
|
|
|
|
|
|
|
для: devil943
(08.01.2008 в 21:32)
| | [^\[url=] замените на (?<!\[url=)
[^\[\/url\]] - аналогично на (?!\[\/url\]) | |
|
|
|
|
|
|
|
для: kasmanaft
(09.01.2008 в 05:30)
| | В результате получается так:
$patern = "/(?<!\[url=)http:\/\/(\S+)(?!\[\/url\])/i";
|
Не работает... | |
|
|
|
|
|
|
|
для: devil943
(09.01.2008 в 16:43)
| | Хм... попробуйте вот так:
$patern = "#(?<!\[url=)http://((?>[^\s\[\]]+))(?!\s*\[\/url\])#i";
А чтобы "пробелы ссылками не становились" придется накуралесить немного:
#(?<!\[url=)(?<!\[url =)(?<!\[url = )(?<!\[url= )......#i
...потому что "смотреть назад" на неопределенное количество символов нельзя... то есть просто (?<!\[url\s*=\s*) - не сработает. | |
|
|
|
|
|
|
|
для: kasmanaft
(09.01.2008 в 20:05)
| | Вот спасибо, все заработало.
А почему вы применяли ! а не ^?
И еще: не могли бы вы тут посмотреть:
http://www.softtime.ru/forum/read.php?id_forum=1&id_theme=47803&page=1 | |
|
|
|
|
|
|
|
для: devil943
(10.01.2008 в 19:13)
| | Ну, ^? я даже не знаю где бы можно было применить... "возможно начало строки" получается.. То есть в любом выражении разницы и не будет применять его или не применять.
А эта конструкция (?<!\[url=) позволяет "заглянуть назад". А именно: четыре стоящих символа перед текущим должны быть не "[url=".
(?!\s*\[\/url\]) - тут: шесть символов после текущего (перед которыми может стоять любое количество пробелов) не должны быть "[/url]".
(?>[^\s\[\]]+) - эта "скушает" максимально возможное количество "не квадратных скобок и пробелов".
UPD похоже, я неправильно понял "^?"...
Ваша [^\[url=] означает: один любой символ, не равный чему-нибудь из "[url=". | |
|
|
|
|
|
|
|
для: kasmanaft
(11.01.2008 в 10:25)
| | Спасибо...
У меня в книжке ! не фигурирует в рерулярках, отрицание ^ ... То есть если оно просто в начале регулярного выражения, то это начало строки, а если квадратных скобках..
Т.е [^url] - это не url | |
|
|
|
|
|
|
|
для: devil943
(11.01.2008 в 16:17)
| | > Т.е [^url] - это не url
Не "не URL", а "не u, r или l". | |
|
|
|
|
|
|
|
для: devil943
(08.01.2008 в 21:07)
| | >Я прав?
Нет.
>Сразу скажу, что оно не работает должным образом... где ошибка7
Ошибка в первую очередь в том, что Вы пытаетесь обсуждать регулярки в неподобающем разделе форума. | |
|
|
|