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

Форум PHP

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

 

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

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

тема: Как организовать поиск записей файлов по маскам вроде досовских?
 
 автор: Void   (29.11.2005 в 21:24)   письмо автору
 
 

Я пишу поисковик для локальной сети и встретился я с такой проблемой: Как можно сделать поиск имен файлов по маскам вроде DOS'овских? Т.е. знаки: ? и *, и их комбинации вроде *_new.a?0. Если можно, выложите код/ссылку на код, который бракует заведомо неверные по условию строки.

   
 
 автор: cheops   (29.11.2005 в 22:44)   письмо автору
 
   для: Void   (29.11.2005 в 21:24)
 

Может конвертировать запрос в регулярные выражения? Заменяя ? и * на ".?" и ".*"

   
 
 автор: Void   (29.11.2005 в 22:47)   письмо автору
 
   для: cheops   (29.11.2005 в 22:44)
 

То есть использовать regex_*? В данном случае это рационально?

   
 
 автор: cheops   (29.11.2005 в 22:51)   письмо автору
 
   для: Void   (29.11.2005 в 22:47)
 

А вы как ищите информацию?
1) По индексному файлу
2) Сканируя директории
3) В базе данных
?

   
 
 автор: Void   (29.11.2005 в 23:11)   письмо автору
 
   для: cheops   (29.11.2005 в 22:51)
 

Я использую таблицу в базе MySQL - в ней находятся поля 'name', 'attr', 'size' и 'path'. Все типа TEXT.

   
 
 автор: cheops   (30.11.2005 в 15:51)   письмо автору
 
   для: Void   (29.11.2005 в 23:11)
 

Путь хранится в поле PATH?

   
 
 автор: Void   (30.11.2005 в 16:40)   письмо автору
 
   для: cheops   (30.11.2005 в 15:51)
 

Именно. Создается рекурсивной функцией и оканчивается слешем. Вроде этого:
downloads/forum/themes/

   
 
 автор: cheops   (01.12.2005 в 01:02)   письмо автору
 
   для: Void   (30.11.2005 в 16:40)
 

Тогда можно воспользоваться поиском при помощи REGEXP, нужно будет только ? заменить на _, а звёздочку оставить без изменений
SELECT * FROM tbl WHERE name REGEXP "/path/_001/*"

Более подробно об этом можно почитать в теме по ссылке http://www.softtime.ru/forum/read.php?id_forum=3&id_theme=807

   
Rambler's Top100
вверх

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