Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум Регулярные Выражения

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Разбор текста
 
 автор: Елена Смирнова   (17.12.2007 в 21:02)   письмо автору
 
 

Есть переменная $text
в ней хранится пользовательский текст, это русские или английские слова, цифры и символы.
Нужно разобрать этот текст, как я понимаю это делается с помощью регулярных выражений.
Требуется, чтобы слова в этом тексте стали ссылками...(только слова, не символы и не цифры)...
Пример:
Привет, я Лена!

Результат:
<a href="view.php?text=Привет">Привет</a>
<a href="view.php?text=я">я</a>
<a href="view.php?text=Лена">Лена</a>

   
 
 автор: Faraon   (17.12.2007 в 21:44)   письмо автору
 
   для: Елена Смирнова   (17.12.2007 в 21:02)
 

Подробнее можно? Что конкретно хранится в переменной $text, для привязки чтобы составить регулярку? Пример приведите.

   
 
 автор: Trianon   (17.12.2007 в 22:00)   письмо автору
 
   для: Елена Смирнова   (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$replacementhtmlspecialchars($in));
  echo 
"$in : $out </br>\r\n";


?>

только с дефисами будут проблемы.
опознать "что-либо" как одно слово уже не получится.

PS. а так, как у Вас написано, делать нельзя.
Символы национальных алфавитов в параметрах URL следует кодировать.

   
 
 автор: exp   (17.12.2007 в 22:17)   письмо автору
 
   для: 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>';

   
 
 автор: Trianon   (17.12.2007 в 22:33)   письмо автору
 
   для: exp   (17.12.2007 в 22:17)
 

так - нельзя.
Почему - я пояснил в постскриптуме.

И такой код будет куда менее терпим к настройкам локали.

   
 
 автор: kasmanaft   (18.12.2007 в 07:27)   письмо автору
 
   для: Trianon   (17.12.2007 в 22:00)
 

> только с дефисами будут проблемы.
> опознать "что-либо" как одно слово уже не получится.

Ну, если нужно, можно, наверное, сей дефис добавить: /([А-Яа-яЁё-]+)/e

   
 
 автор: Елена Смирнова   (18.12.2007 в 19:29)   письмо автору
 
   для: 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$replacementhtmlspecialchars($in)); 
  echo 
"$in : $out </br>\r\n"


?> 


В данном случае, чтобы "я" не становилась ссылкой? толко, две и более букв.

   
 
 автор: kasmanaft   (18.12.2007 в 19:32)   письмо автору
 
   для: Елена Смирнова   (18.12.2007 в 19:29)
 

Попробуйте вот так: /([А-Яа-яЁё]{2,})/e

>> так не работает
Странно, должно работать...

   
 
 автор: Елена Смирнова   (18.12.2007 в 19:37)   письмо автору
 
   для: kasmanaft   (18.12.2007 в 19:32)
 

Ага, пасиб... Получилось... и английский обрабатывает.

   
 
 автор: Елена Смирнова   (18.12.2007 в 19:38)   письмо автору
 
   для: Елена Смирнова   (18.12.2007 в 19:37)
 

Еще вопросик, у меня в БД хранится дата в виде 200711181938 как мне ее переделать
в 19:38 18.11.2007
и тоже самое проделать с 20071118, чтобы получилось 18.11.2007

   
 
 автор: kasmanaft   (18.12.2007 в 20:18)   письмо автору
 
   для: Елена Смирнова   (18.12.2007 в 19:38)
 

Тут лучше без регулярных выражений обойтись:
<?php  

$date 
"200711181938";
echo 
substr($date82) . ":" .
     
substr($date102) . " " .
     
substr($date62) . "." .
     
substr($date42) . "." .
     
substr($date04), "<br />";

$date "20071118";
echo 
substr($date62) . "." .
     
substr($date42) . "." .
     
substr($date04);

?>

   
 
 автор: Trianon   (18.12.2007 в 22:38)   письмо автору
 
   для: Елена Смирнова   (18.12.2007 в 19:38)
 

Для решения этой проблемы наиболее разумно применить функцию MySQL DATE_FORMAT()

   
 
 автор: kasmanaft   (19.12.2007 в 13:47)   письмо автору
 
   для: Trianon   (18.12.2007 в 22:38)
 

"200711181938" - это не timestamp... "оно" проглотит такую строку?

> Тогда дефис будет захватываться в местах совершенно излишних. Например, как перенос.
Ну перенос... Если это перенос, то его вообще, наверное, убрать надо, чтобы слово на две части не рвать....
Дану, кто в наше время переносы использует :)

Но, если сильно надо, можно придумать что-то вроде:
/([А-Яа-яЁё]+(?:-[А-Яа-яЁё]+)*)/e

PS я лишь предлагаю.. пусть Елена сама выбирает.


UPD А... понял, что Вы имели ввиду. Так действительно было бы неправильно. Но сейчас минимальную длинну слова увеличили до двух - перенос, тире, по идее, не должны больше мешать...

   
 
 автор: Faraon   (19.12.2007 в 21:28)   письмо автору
 
   для: Trianon   (18.12.2007 в 22:38)
 

>"200711181938" - это не timestamp... "оно" проглотит такую строку?
Trianon и как Вы собрались преобразовать такую строку через DATE_FORMAT ?

   
 
 автор: Trianon   (18.12.2007 в 22:41)   письмо автору
 
   для: kasmanaft   (18.12.2007 в 07:27)
 

Тогда дефис будет захватываться в местах совершенно излишних. Например, как перенос.

   
 
 автор: Елена Смирнова   (19.12.2007 в 18:26)   письмо автору
 
   для: Trianon   (18.12.2007 в 22:41)
 

Помойму, Вы немного не так поняли, мне требуется преобразовать дату и время хранимое в БД как 200711181938.
Вот это никак не подходит, так как время то всегда разное.

<?php   

$date 
"200711181938"
echo 
substr($date82) . ":" 
     
substr($date102) . " " 
     
substr($date62) . "." 
     
substr($date42) . "." 
     
substr($date04), "<br />"

$date "20071118"
echo 
substr($date62) . "." 
     
substr($date42) . "." 
     
substr($date04); 

?> 



MySQL DATE_FORMAT()

Это используется перед записью или выводом?
Если перед записью, то мне не подходит, так как у меня с датой происходят разные математические действия.
Покажите пример использования. MySQL DATE_FORMAT() или точное рег.выр.

   
 
 автор: Loki   (19.12.2007 в 22:52)   письмо автору
 
   для: Елена Смирнова   (19.12.2007 в 18:26)
 


SELECT DATE_FORMAT( field , '%Y%m%d%H%i' ) as var FROM table

   
 
 автор: kasmanaft   (20.12.2007 в 05:51)   письмо автору
 
   для: Елена Смирнова   (19.12.2007 в 18:26)
 

>> Вот это никак не подходит, так как время то всегда разное.
То есть "разное" ? Если это ГГГГММДДччмм, то всегда будет работать. А если оно всё время разное, то работать не будет в любом случае, как ни крути :))

Loki, это Вы таким образом извлекете из БД ту же строку (даже если получится).

   
 
 автор: Loki   (20.12.2007 в 12:03)   письмо автору
 
   для: kasmanaft   (20.12.2007 в 05:51)
 

гм... а задачу понял совершенно обратным образом... ну если человеку нравится хранить дату как текст - ее право.

Тогда можно воспользоваться такой конструкцией:
<?
echo date("Y-m-d H:m"strtotime('200712201216'));


Но это полная порнография.

   
 
 автор: Trianon   (20.12.2007 в 10:17)   письмо автору
 
   для: Елена Смирнова   (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 - поле результата, в котором эти данные извлекаются

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования