Meu entendimento é que a sessão do IPython inicia o log para que o basicConfig não funcione. Aqui está a configuração que funciona para mim (eu gostaria que isso não fosse tão grosseiro, pois eu quero usá-lo em quase todos os meus notebooks):
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)
Agora, quando eu corro:
logging.error('hello!')
logging.debug('This is a debug message')
logging.info('this is an info message')
logging.warning('tbllalfhldfhd, warning.')
Eu recebo um arquivo "mylog.log" no mesmo diretório do meu notebook que contém:
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.
Observe que, se você executar novamente isso sem reiniciar a sessão do IPython, ele gravará entradas duplicadas no arquivo, pois agora haverá dois manipuladores de arquivos definidos