Я всего пару недель изучаю python без предыдущего опыта программирования, поэтому прошу прощения за свое невежество.
Я пытаюсь использовать комбинацию модулей для мониторинга папки на наличие новых файлов (сторожевой таймер), оповещения о любом событии (модуль ведения журнала), а затем отправить оповещение на мою электронную почту (smtplib).
Здесь я нашел действительно хороший пример: -python-watchdog">Как запустить функцию, когда что-либо изменяется в каталоге с помощью Python Watchdog?
Однако я застрял, пытаясь сохранить информацию журнала в качестве переменной для использования в своем сообщении электронной почты. Мне интересно, нужно ли мне выводить информацию журнала в файл, а затем читать строку для использования в качестве переменной.
Во всяком случае, это то, что у меня есть. Любая помощь приветствуется. А пока я продолжу гуглить.
import sys
import time
import logging
from watchdog.observers import Observer
from watchdog.events import LoggingEventHandler
import smtplib
class Event(LoggingEventHandler):
def on_any_event(self, event):
logMsg = logging.basicConfig(level=logging.INFO,
format='%(asctime)s - %(message)s',
datefmt='%Y-%m-%d %H:%M:%S')
sender = '[email protected]'
receiver = '[email protected]'
message = """From: No Reply <[email protected]>
TO: Test User <[email protected]>
Subject: Folder Modify Detected
The following change was detected: """ + str(logMsg)
mail = smtplib.SMTP('mailServer.myDomain.com', 25)
mail.ehlo()
mail.starttls()
mail.sendmail(sender, receiver, message)
mail.close()
if __name__ == "__main__":
path = sys.argv[1] if len(sys.argv) > 1 else '.'
event_handler = Event()
observer = Observer()
observer.schedule(event_handler, path, recursive=False)
observer.start()
try:
while True:
time.sleep(1)
except KeyboardInterrupt:
observer.stop()
observer.join()