У меня проблемы с обнаружением ошибок внутри обработчика событий от pyinotify. Я пытаюсь выполнить некоторую обработку файлов, которые были только что закрыты после записи.
Вот упрощенная версия моего скрипта:
import pyinotify
import asyncore
mask = pyinotify.IN_CLOSE_WRITE
class EventHandler(pyinotify.ProcessEvent):
def process_IN_CLOSE_WRITE(self, event):
try:
do_stuff()
except BaseException as e:
print "Exception:" + str(e)
pass
if __name__ == "__main__":
try:
wm = pyinotify.WatchManager()
notifier = pyinotify.AsyncNotifier(wm, EventHandler())
wdd = wm.add_watch('/dir-to-watch/', mask, rec=True)
asyncore.loop()
except:
print "Unhandled error!"
print "Details:" + str(e)
print "Continuing anyway..."
pass
Кажется, что когда я получаю ошибку или исключение, ни мой except в основном цикле, ни мой except BaseException в обработчике событий не перехватывают ошибку или исключения.
Я получаю сообщения, начинающиеся так:
ошибка: незахваченное исключение Python, закрытие канала (: [Errno 2] Нет такого файла или каталога:
Итак, мой вопрос: как можно поймать эти исключения?