Rozumiem, że sesja IPython rozpoczyna rejestrowanie, więc basicConfig nie działa. Oto konfiguracja, która działa dla mnie (chciałbym, żeby nie wyglądała tak obrzydliwie, ponieważ chcę jej używać do prawie wszystkich moich notebooków):
import logging
logger = logging.getLogger()
fhandler = logging.FileHandler(filename='mylog.log', mode='a')
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
fhandler.setFormatter(formatter)
logger.addHandler(fhandler)
logger.setLevel(logging.DEBUG)
Teraz kiedy biegnę:
logging.error('hello!')
logging.debug('This is a debug message')
logging.info('this is an info message')
logging.warning('tbllalfhldfhd, warning.')
Otrzymuję plik „mylog.log” w tym samym katalogu co mój notatnik, który zawiera:
2015-01-28 09:49:25,026 - root - ERROR - hello!
2015-01-28 09:49:25,028 - root - DEBUG - This is a debug message
2015-01-28 09:49:25,029 - root - INFO - this is an info message
2015-01-28 09:49:25,032 - root - WARNING - tbllalfhldfhd, warning.
Zwróć uwagę, że jeśli uruchomisz to ponownie bez ponownego uruchamiania sesji IPython, zapisze zduplikowane wpisy do pliku, ponieważ byłyby teraz zdefiniowane dwa programy obsługi plików