Модераторы: Poseidon, Snowy, bems, MetalFan
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Очень быстрый поиск текста в текстовом файле!? даже самых больших размеров 
:(
    Опции темы
Nicholas
  Дата 14.11.2008, 17:16 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 436
Регистрация: 30.9.2004

Репутация: нет
Всего: 0



Подскажите как быстро определить есть ли нужный мне текст в текстово файле?
Например мне надо узнать сколько раз повторяется какое нибудь слово в текстовом файле...
Нужен хороший способ, чтоб работал не только для маленьких но и для больших файлв шустро!

 smile 
PM MAIL ICQ   Вверх
Poseidon
Дата 14.11.2008, 17:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Delphi developer
****


Профиль
Группа: Комодератор
Сообщений: 5273
Регистрация: 4.2.2005
Где: Гомель, Беларусь

Репутация: 53
Всего: 133



Цитата(Nicholas @  14.11.2008,  17:16 Найти цитируемый пост)
Подскажите как быстро определить есть ли нужный мне текст в текстово файле?
Функция pos

Цитата(Nicholas @  14.11.2008,  17:16 Найти цитируемый пост)
мне надо узнать сколько раз повторяется какое нибудь слово в текстовом файле
TRegExpr

Цитата(Nicholas @  14.11.2008,  17:16 Найти цитируемый пост)
Нужен хороший способ, чтоб работал не только для маленьких но и для больших файлв шустро!
В любом случае придется заргужать в память и работать с текстом в памяти. Большие файлы можно загружать поблочно. При этом можно несколько блоков загружать одновременно несколькими потоками.



--------------------
Если хочешь, что бы что-то работало - используй написанное, 
если хочешь что-то понять - пиши сам...
PM MAIL ICQ   Вверх
aleksh
Дата 14.11.2008, 17:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 609
Регистрация: 8.7.2008

Репутация: 3
Всего: 13



чисто теоретически можно извращаться, но довольно трудно создать условия в которых какой-нибудь код будет работать быстрее pos

а конкретнее можно?
PM MAIL   Вверх
aktuba
Дата 15.11.2008, 02:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Смышленный
***


Профиль
Группа: Завсегдатай
Сообщений: 1915
Регистрация: 24.4.2006
Где: Планета Земля

Репутация: 16
Всего: 38



Цитата(aleksh @  14.11.2008,  18:34 Найти цитируемый пост)
чисто теоретически можно извращаться, но довольно трудно создать условия в которых какой-нибудь код будет работать быстрее pos

Легко!!! Используй маш.коды или асм. Или, если известна структура, можно оптимизировать алгоритм.


--------------------
user posted image
PM MAIL WWW Skype   Вверх
aleksh
Дата 15.11.2008, 11:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 609
Регистрация: 8.7.2008

Репутация: 3
Всего: 13



Цитата(aktuba @  15.11.2008,  02:43 Найти цитируемый пост)
можно оптимизировать алгоритм

оптимизировать можно что угодно, но все же
Цитата(aleksh @  14.11.2008,  17:34 Найти цитируемый пост)
чисто теоретически можно извращаться, но довольно трудно создать условия

а во вторых,
Цитата(aktuba @  15.11.2008,  02:43 Найти цитируемый пост)
Используй маш.коды или асм

мы же в топике посвещенному делфи
PM MAIL   Вверх
Alexeis
Дата 15.11.2008, 15:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Амеба
Group Icon


Профиль
Группа: Админ
Сообщений: 11743
Регистрация: 12.10.2005
Где: Зеленоград

Репутация: 109
Всего: 459



Цитата(aktuba @  15.11.2008,  01:43 Найти цитируемый пост)
Легко!!! Используй маш.коды или асм. Или, если известна структура, можно оптимизировать алгоритм. 

  Ты смотрел реализацию pos? В Delphi 2007 так и так чистый асм. Это уже сторонняя реализация, подобранная с точки зрения максимальной скорости.


--------------------
Vit вечная память.

Обсуждение действий администрации форума производятся только в этом форуме

гениальность идеи состоит в том, что ее невозможно придумать
PM ICQ Skype   Вверх
Akella
Дата 15.11.2008, 16:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 36
Всего: 329



Цитата(Nicholas @  14.11.2008,  17:16 Найти цитируемый пост)
но и для больших файлв шустро!

на сколько больших? Ну у меня 1-2-3 мегабайтные файлы загружаются довольно быстро в StringList полностью и с пом. регулярок в каждой строке идёт поиск нужных символов, всё проходит достаточно быстро даже при том, что программа найденные символы ещё и ищет по таблице БД, в которой почти 200 тыщ записей, к которой доступ по локальной сети, мало того, ещё и комп старинный на сокете А. 1-но мегабайтный файл обрабатывается менее чем за 20 секунд.

Это сообщение отредактировал(а) Akella - 15.11.2008, 16:11
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Общие вопросы"
SnowyMetalFan
bemsPoseidon
Rrader

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, MetalFan, bems, Poseidon, Rrader.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1072 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.