|
|
|
| Здравствуйте!
У меня возникла небольшая проблема: нужно вытащить из неизвестной строки, то, что запросит пользователь. Например, такой запрос: "маркетинговые исследования". Мне нужно, чтобы на этот запрос "отвечала" и строка 'исследования проводили маркетинговые компании', и строка 'маркетинговые компании публикуют исследования' (между словами - до 50 любых символов, сами слова в любом порядке, в запросе - до 3х слов).
Объяснил немного кривовато, но, может, кто-нибудь и поймет. Очень надеюсь на помощь! | |
|
|
|
|
|
|
|
для: Я
(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);
?>
|
| |
|
|
|
|
|
|
|
для: Poison
(12.03.2007 в 23:16)
| | Спасибо!
Но я не уточнил, что запрос идет в MySql и обрабатывается так:
mysql_query("select * from catalog where description REGEXP '$word1|$word2' ");
|
где $word1="исследования * маркетинговые", а $word2="маркетинговые * исследования".
Т.е. нужно составить запрос на RegExp, т.к. предоставленный Вами код читается как цельная строка. | |
|
|
|
|
|
|
|
для: Я
(13.03.2007 в 12:35)
| | Тогда вам проще обратиться к полнотекстовому поиску. | |
|
|
|
|
|
|
|
для: Я
(13.03.2007 в 12:35)
| | а чем не нравится вариант
<?
mysql_query("select * from catalog where description LIKE '%$word1%' AND description LIKE '%$word2%' ");
|
или вообще воспользоваться полнотекстовым поиском... | |
|
|
|