|
|
|
| Я пишу поисковик для локальной сети и встретился я с такой проблемой: Как можно сделать поиск имен файлов по маскам вроде DOS'овских? Т.е. знаки: ? и *, и их комбинации вроде *_new.a?0. Если можно, выложите код/ссылку на код, который бракует заведомо неверные по условию строки. | |
|
|
|
|
|
|
|
для: Void
(29.11.2005 в 21:24)
| | Может конвертировать запрос в регулярные выражения? Заменяя ? и * на ".?" и ".*" | |
|
|
|
|
|
|
|
для: cheops
(29.11.2005 в 22:44)
| | То есть использовать regex_*? В данном случае это рационально? | |
|
|
|
|
|
|
|
для: Void
(29.11.2005 в 22:47)
| | А вы как ищите информацию?
1) По индексному файлу
2) Сканируя директории
3) В базе данных
? | |
|
|
|
|
|
|
|
для: cheops
(29.11.2005 в 22:51)
| | Я использую таблицу в базе MySQL - в ней находятся поля 'name', 'attr', 'size' и 'path'. Все типа TEXT. | |
|
|
|
|
|
|
|
для: Void
(29.11.2005 в 23:11)
| | Путь хранится в поле PATH? | |
|
|
|
|
|
|
|
для: cheops
(30.11.2005 в 15:51)
| | Именно. Создается рекурсивной функцией и оканчивается слешем. Вроде этого:
downloads/forum/themes/ | |
|
|
|
|
|
|
|
для: 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 | |
|
|
|