|
|
|
| Есть переменная $text
в ней хранится пользовательский текст, это русские или английские слова, цифры и символы.
Нужно разобрать этот текст, как я понимаю это делается с помощью регулярных выражений.
Требуется, чтобы слова в этом тексте стали ссылками...(только слова, не символы и не цифры)...
Пример:
Привет, я Лена!
Результат:
<a href="view.php?text=Привет">Привет</a>
<a href="view.php?text=я">я</a>
<a href="view.php?text=Лена">Лена</a> | |
|
|
|
|
|
|
|
для: Елена Смирнова
(17.12.2007 в 21:02)
| | Подробнее можно? Что конкретно хранится в переменной $text, для привязки чтобы составить регулярку? Пример приведите. | |
|
|
|
|
|
|
|
для: Елена Смирнова
(17.12.2007 в 21:02)
| | Примерно так....
<?php
$in = "Привет, я Лена!";
function user_repl($t)
{
$enc = rawurlencode($t);
return "<a href=view.php?text=\"$enc\">$t</a>";
}
$pattern = '/([А-Яа-яЁё]+)/e';
$replacement = "user_repl('\\1')";
$out = preg_replace($pattern, $replacement, htmlspecialchars($in));
echo "$in : $out </br>\r\n";
?>
|
только с дефисами будут проблемы.
опознать "что-либо" как одно слово уже не получится.
PS. а так, как у Вас написано, делать нельзя.
Символы национальных алфавитов в параметрах URL следует кодировать. | |
|
|
|
|
|
|
|
для: Trianon
(17.12.2007 в 22:00)
| | можно ещё так , чтобы были английские и неанглийскии буквы
<?php
$str = ':) 100лет непреобразовывается а 100 лет да';
$str = preg_replace( '#\b([[:alpha:]]+)\b#', '<a href="?word=$1">$1</a>', $str);
echo $str . '<hr>';
|
| |
|
|
|
|
|
|
|
для: exp
(17.12.2007 в 22:17)
| | так - нельзя.
Почему - я пояснил в постскриптуме.
И такой код будет куда менее терпим к настройкам локали. | |
|
|
|
|
|
|
|
для: Trianon
(17.12.2007 в 22:00)
| | > только с дефисами будут проблемы.
> опознать "что-либо" как одно слово уже не получится.
Ну, если нужно, можно, наверное, сей дефис добавить: /([А-Яа-яЁё-]+)/e | |
|
|
|
|
|
|
|
для: kasmanaft
(18.12.2007 в 07:27)
| | Вот эта конструкция отлично работает, но как в нее добавить, чтобы слова менее чем из 2-х букв не обрабатывались?
<?php
$in = "Привет, я Лена!";
function user_repl($t)
{
$enc = rawurlencode($t);
return "<a href=view.php?text=\"$enc\">$t</a>";
}
$pattern = '/([А-Яа-яЁё]+)/e';
$replacement = "user_repl('\\1')";
$out = preg_replace($pattern, $replacement, htmlspecialchars($in));
echo "$in : $out </br>\r\n";
?>
|
В данном случае, чтобы "я" не становилась ссылкой? толко, две и более букв. | |
|
|
|
|
|
|
|
для: Елена Смирнова
(18.12.2007 в 19:29)
| | Попробуйте вот так: /([А-Яа-яЁё]{2,})/e
>> так не работает
Странно, должно работать... | |
|
|
|
|
|
|
|
для: kasmanaft
(18.12.2007 в 19:32)
| | Ага, пасиб... Получилось... и английский обрабатывает. | |
|
|
|
|
|
|
|
для: Елена Смирнова
(18.12.2007 в 19:37)
| | Еще вопросик, у меня в БД хранится дата в виде 200711181938 как мне ее переделать
в 19:38 18.11.2007
и тоже самое проделать с 20071118, чтобы получилось 18.11.2007 | |
|
|
|
|
|
|
|
для: Елена Смирнова
(18.12.2007 в 19:38)
| | Тут лучше без регулярных выражений обойтись:
<?php
$date = "200711181938";
echo substr($date, 8, 2) . ":" .
substr($date, 10, 2) . " " .
substr($date, 6, 2) . "." .
substr($date, 4, 2) . "." .
substr($date, 0, 4), "<br />";
$date = "20071118";
echo substr($date, 6, 2) . "." .
substr($date, 4, 2) . "." .
substr($date, 0, 4);
?>
|
| |
|
|
|
|
|
|
|
для: Елена Смирнова
(18.12.2007 в 19:38)
| | Для решения этой проблемы наиболее разумно применить функцию MySQL DATE_FORMAT() | |
|
|
|
|
|
|
|
для: Trianon
(18.12.2007 в 22:38)
| | "200711181938" - это не timestamp... "оно" проглотит такую строку?
> Тогда дефис будет захватываться в местах совершенно излишних. Например, как перенос.
Ну перенос... Если это перенос, то его вообще, наверное, убрать надо, чтобы слово на две части не рвать....
Дану, кто в наше время переносы использует :)
Но, если сильно надо, можно придумать что-то вроде:
/([А-Яа-яЁё]+(?:-[А-Яа-яЁё]+)*)/e
PS я лишь предлагаю.. пусть Елена сама выбирает.
UPD А... понял, что Вы имели ввиду. Так действительно было бы неправильно. Но сейчас минимальную длинну слова увеличили до двух - перенос, тире, по идее, не должны больше мешать... | |
|
|
|
|
|
|
|
для: Trianon
(18.12.2007 в 22:38)
| | >"200711181938" - это не timestamp... "оно" проглотит такую строку?
Trianon и как Вы собрались преобразовать такую строку через DATE_FORMAT ? | |
|
|
|
|
|
|
|
для: kasmanaft
(18.12.2007 в 07:27)
| | Тогда дефис будет захватываться в местах совершенно излишних. Например, как перенос. | |
|
|
|
|
|
|
|
для: Trianon
(18.12.2007 в 22:41)
| | Помойму, Вы немного не так поняли, мне требуется преобразовать дату и время хранимое в БД как 200711181938.
Вот это никак не подходит, так как время то всегда разное.
<?php
$date = "200711181938";
echo substr($date, 8, 2) . ":" .
substr($date, 10, 2) . " " .
substr($date, 6, 2) . "." .
substr($date, 4, 2) . "." .
substr($date, 0, 4), "<br />";
$date = "20071118";
echo substr($date, 6, 2) . "." .
substr($date, 4, 2) . "." .
substr($date, 0, 4);
?>
|
Это используется перед записью или выводом?
Если перед записью, то мне не подходит, так как у меня с датой происходят разные математические действия.
Покажите пример использования. MySQL DATE_FORMAT() или точное рег.выр. | |
|
|
|
|
|
|
|
для: Елена Смирнова
(19.12.2007 в 18:26)
| |
SELECT DATE_FORMAT( field , '%Y%m%d%H%i' ) as var FROM table
|
| |
|
|
|
|
|
|
|
для: Елена Смирнова
(19.12.2007 в 18:26)
| | >> Вот это никак не подходит, так как время то всегда разное.
То есть "разное" ? Если это ГГГГММДДччмм, то всегда будет работать. А если оно всё время разное, то работать не будет в любом случае, как ни крути :))
Loki, это Вы таким образом извлекете из БД ту же строку (даже если получится). | |
|
|
|
|
|
|
|
для: kasmanaft
(20.12.2007 в 05:51)
| | гм... а задачу понял совершенно обратным образом... ну если человеку нравится хранить дату как текст - ее право.
Тогда можно воспользоваться такой конструкцией:
<?
echo date("Y-m-d H:m", strtotime('200712201216'));
|
Но это полная порнография. | |
|
|
|
|
|
|
|
для: Елена Смирнова
(19.12.2007 в 18:26)
| | Предлагается сразу извлекать дату из базы в нужном формате.
$res = "SELECT DATE_FORMAT( stored_datetime , '%d.%m.%Y %H:%s' ) as formatted_datetime , table.*
FROM table
ORDER BY stored_datetime"
|
while($row = mysql_fetch_assoc($res))
print($row['formatted_datetime'] ."<br>";
|
stored_datetime - поле таблицы, в котором хранится дата, время.В нем же идет сортировка.
formatted_datetime - поле результата, в котором эти данные извлекаются | |
|
|
|