Here is the takeaway to setup logger in your python script.
It will rotate daily and maintains log file for 7 days.
|  |  | 
Call the function once at the beginning and call logging.getLogger(‘my-logger’) wherever you want to log.
getLogger is singleton hence will preserve the configuration if you provide same name ‘my-logger’ to getLogger.
|  |  | 
Breakdown explanation
|  |  | 
Typically initlogger should be called once.
When for some reason it is called again, this check will prevent same handler to be attached.
When you find log message appearing twice, it is most likely because of multiple handler attached.
|  |  | 
TimedRotatingFileHandler is a predefined handler which does log rotation for you.
What you need to do is specify the type of interval in when and at most how much files to keep backupCount.
You can change the interval of when by specifying interval argument (default interval=1).
According to the reference, log is rotated at time handler got attached.
|  |  | 
Formatter allows you to structure the content of the log message.
%(message)s is required if you want to insert your message in the log.
Output example below:
|  |  |