Я пытаюсь найти решение проблемы, которая у меня есть ... У меня есть большая доля, которая содержит сотни тысяч (если не миллионы) файлов и новых файлов, поступающих каждую секунду. Я пытаюсь написать приложение, которое ускорит поиск файлов в общей папке. Моя идея состояла в том, чтобы вставить все имена файлов в Redis DB в формате: {'file_name','file_path'}
, а не когда файл нужен, чтобы потянуть его путь из базы данных ... Проблема начинается, когда я пытаюсь индексировать все старые файлы (я предполагаю, что это займет не менее нескольких часов), одновременно прислушиваясь к новым файлам, которые поступают во время процесса. Это пример того, что I'am пытается сделать:Прослушивание новых файлов Python
import redis
import os
r = redis.StrictRedis(host='localhost',port=6379,db=0)
for root, dirs, files in os.walk(r'D:\\'):
for file in files:
r.set(os.path.basename(file),os.path.join(root, file))
print 'The file %s was succefuly added' %os.path.basename(file)
, как я, как предполагается модифицировать код, который я буду держать прослушивание для новых файлов?
спасибо за вашу помощь! =)
На какой платформе вы работаете? Похоже на окна. –
Yup, iam, запускающий код на базе windows.the, является NAS. – NinjaX
Почему бы вам не запустить сценарий, похожий на службы, в фоновом режиме, который продолжает работать после этого. Он проверяет наличие новых прибывающих файлов. И начальное индексирование, которое вы могли бы обрабатывать по другому сценарию (например, тот, который вы уже писали). – Qdeep