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

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

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

 

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

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

тема: Работа со строками
 
 автор: Я   (12.03.2007 в 20:13)   письмо автору
 
 

Здравствуйте!

У меня возникла небольшая проблема: нужно вытащить из неизвестной строки, то, что запросит пользователь. Например, такой запрос: "маркетинговые исследования". Мне нужно, чтобы на этот запрос "отвечала" и строка 'исследования проводили маркетинговые компании', и строка 'маркетинговые компании публикуют исследования' (между словами - до 50 любых символов, сами слова в любом порядке, в запросе - до 3х слов).

Объяснил немного кривовато, но, может, кто-нибудь и поймет. Очень надеюсь на помощь!

   
 
 автор: Poison   (12.03.2007 в 23:16)   письмо автору
 
   для: Я   (12.03.2007 в 20:13)
 

что-то вроде этого:


<?
$text 
= <<<HTML
Здравствуйте!
У меня возникла небольшая проблема: нужно вытащить из неизвестной строки, то, что запросит пользователь. Например, такой запрос: "маркетинговые
исследования". Мне нужно, чтобы на этот запрос "отвечала" и строка 'исследования проводили
маркетинговые компании', и строка 'маркетинговые компании
публикуют исследования' (между словами - до 50 любых символов, сами
слова в любом порядке, в запросе - до 3х слов).
Объяснил немного кривовато, но, может, кто-нибудь и поймет.
Очень надеюсь на помощь!
HTML;
$query "маркетинговые исследования";
preg_match_all("/((".str_replace(" ""|"$query).")([\w\d\s\n_\-]{0,50})(".str_replace(" ""|"$query)."))+/si"$text$result) ;
print_r($result);
?>

   
 
 автор: Я   (13.03.2007 в 12:35)   письмо автору
 
   для: Poison   (12.03.2007 в 23:16)
 

Спасибо!
Но я не уточнил, что запрос идет в MySql и обрабатывается так:

mysql_query("select * from catalog where description REGEXP '$word1|$word2' ");

где $word1="исследования * маркетинговые", а $word2="маркетинговые * исследования".
Т.е. нужно составить запрос на RegExp, т.к. предоставленный Вами код читается как цельная строка.

   
 
 автор: cheops   (13.03.2007 в 13:17)   письмо автору
 
   для: Я   (13.03.2007 в 12:35)
 

Тогда вам проще обратиться к полнотекстовому поиску.

   
 
 автор: Loki   (13.03.2007 в 13:24)   письмо автору
 
   для: Я   (13.03.2007 в 12:35)
 

а чем не нравится вариант
<?
mysql_query
("select * from catalog where description LIKE '%$word1%' AND description LIKE '%$word2%' ");

или вообще воспользоваться полнотекстовым поиском...

   
Rambler's Top100
вверх

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