Hide keyboard shortcuts

Hot-keys on this page

r m x p   toggle line displays

j k   next/prev highlighted chunk

0   (zero) top of page

1   (one) first highlighted chunk

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

"""Some sensible defaults for logging 

 

Designed for applications or interactive use -- not importing in library code. 

The 'stems' logger is setup for library use with a NullHandler in 

``stems/__init__.py``. 

""" 

import logging 

 

DEFAULT_LOG_FORMAT = ' '.join( 

('%(asctime)s', 

'%(levelname)s', 

'%(lineno)s', 

'%(module)s.%(funcName)s', 

'%(message)s', ) 

) 

DEFAULT_LOG_DATE_FORMAT = '%H:%M:%S' 

 

 

def setup_logger(logger='stems', 

fmt=DEFAULT_LOG_FORMAT, 

datefmt=DEFAULT_LOG_DATE_FORMAT, 

level=logging.INFO, 

handler=None, 

replace_handler=True): 

""" Setup and return a logger with formatter and handler 

 

Parameters 

---------- 

logger : logging.Logger or str, optional 

Logger, or name of logger to use 

fmt : str, optional 

Format string for ``logging.Formatter`` 

datefmt : str, optional 

Date format string for ``logging.Formatter`` 

level : int or str, optional 

Level for logging passed to ``logging.Logger.setLevel`` 

handler : logging.Handler or None, optional 

Specify a handler to use. Defaults to a newly created 

``logging.StreamHandler``. 

replace_handler : bool, optional 

Replace all existing handlers (otherwise appends handler) 

 

Returns 

------- 

logging.Logger 

Configured logger 

""" 

formatter = logging.Formatter(fmt, datefmt) 

handler = handler or logging.StreamHandler() 

handler.setFormatter(formatter) 

 

if not isinstance(logger, logging.Logger): 

logger = logging.getLogger(logger) 

 

if replace_handler: 

logger.handlers = [handler] 

else: 

logger.addHandler(handler) 

logger.setLevel(level) 

 

return logger