11
how to send the icecream output to a log file? [solved]
(lemmy.eco.br)
Welcome to the Python community on the programming.dev Lemmy instance!
Past
November 2023
October 2023
July 2023
August 2023
September 2023
Overwriting
sys.stdout
andsys.stderr
seems like a Bad Idea™.Browsing the icecream source code, it looks like you can do this:
And then just make sure the logger is configured to actually print at DEBUG level.
Thanks, tried the next
But didn't create the log file and the output was printed on the screen and not on log file(that was never created anyway)
Just to confirm, if you change
ic('test')
tologger.debug('test')
it works as expected? I.e. it creates the log file?Edit: Also if you change the output format of the logger and use it as the
outputFunction
toic
, does it include the customized format?I just want to confirm if your
ic
is routing through the logger or not, to know if it's a problem with your logging config or withic
.EDIT: I think I had something wrong on the logging.basicConfig() because now is creating the .log file when running that line and then the ic() is writing correctly on the log file.
Edit 2: I found what was happening, I was using another directory and now found the og log file with all the tests that were supposed lost.
Thanks for your help.
logger.debug('test') created the log file and logged test, after that ic('test') wrote correctly on the log file.
Restating the kernel and running again directly with ic('test') it wrote on the already existing log file.
So, to recap. If the .log file doesn't exists, ic() didn't create the file and nothing is logged, if the the log file already exists, then the ic() wrote correctly on the log file.
The only missing part is how to create the log file without needing of the logger.debub('').
Tried to create an empty log file with open('logfile.log', 'a').close() and the log file is created but is useless (dosen't even write the logger.debug('test') output)