一、定义日志打印方式

如果我们运行自己的程序,有时候需要记录程序运行过程中出现的问题或者信息。可以运用日志模块logging来记录,该模块日志格式可以根据用户需求来自己定义。

常见打印日志信息形式如下:

import logging
logging.debug("========定义要打印的内容====debug①===========")
logging.info("=========定义要打印的内容====info②===========")
logging.warning("======定义要打印的内容====warning③===========")

默认情况下,logging将日志打印到屏幕,日志级别为WARNING;

日志级别优先关系为:CRITICAL>ERROR>WARNING>INFO>DEBUG>NOTSET,

对于日志等级:

CRITICAL = 50
FATAL = CRITICAL
ERROR = 40
WARNING = 30
WARN = WARNING
INFO = 20
DEBUG = 10
NOTSET = 0

当然也可以根据自己的需求定义优先级别,从以上日志优先级别屏幕上打印的内容为:

WARNING:root;======定义要打印的内容====warning③===========

二、通过logging.basicConfig函数对日志的输出格式进行配置

#!/usr/bin/env python
# -*- coding:utf8 -*-
import logging
def logs(arg):
         logging.basicConfig(level=logging.DEBUG,
                            format='%(asctime)s %(message)s',
                            datefmt='%Y-%m-%d %H:%M:%S',
                            filename='myapp.log',
                            filemode='w')
         logging.debug(arg)
         logging.info(arg)
         logging.warning(arg)
logs('python is language')
[root@Python log]# python log.py
[root@Python log]# cat myapp.log 
2016-01-27 10:44:57 python is language
2016-01-27 10:44:57 python is language
2016-01-27 10:44:57 python is language

logging.basicConfig函数各参数:

filename: 指定日志文件名
filemode: 和file函数意义相同,指定日志文件的打开模式,'w'或'a'
format: 指定输出的格式和内容,format可以输出很多有用信息,如上例所示:
 %(levelno)s: 打印日志级别的数值
 %(levelname)s: 打印日志级别名称
 %(pathname)s: 打印当前执行程序的路径,其实就是sys.argv[0]
 %(filename)s: 打印当前执行程序名
 %(funcName)s: 打印日志的当前函数
 %(lineno)d: 打印日志的当前行号
 %(asctime)s: 打印日志的时间
 %(thread)d: 打印线程ID
 %(threadName)s: 打印线程名称
 %(process)d: 打印进程ID
 %(message)s: 打印日志信息
datefmt: 指定时间格式,同time.strftime()
level: 设置日志级别,默认为logging.WARNING
stream: 指定将日志的输出流,可以指定输出到sys.stderr,sys.stdout或者文件,默认输出到sys.stderr,当stream和filename同时指定时,stream被忽略

三、运行logging模块记录程序操作

有如下日志定义文件(log.py):

[root@Python log]# cat log.py
#!/usr/bin/env python
# -*- coding:utf8 -*-
import logging
def logs(arg):
         logging.basicConfig(level=logging.DEBUG,
                            format='%(asctime)s %(message)s',
                            datefmt='%Y-%m-%d %H:%M:%S',
                            filename='shopping.log',
                            filemode='a')
         logging.info(arg)
[root@Python log]#


应用程序内容如下:

[root@Python log]# cat shopping.py 
#!/usr/bin/env python
# -*- coding:utf8 -*-
from log import logs
user_dict={'apple':4.5,'pear':3.3,'banana':2.5,'tomato':1.5}
ch_fruit = raw_input("请输入要买的水果:")
num=int(raw_input("请输入要买入水果的重量:"))
total_prices= user_dict[ch_fruit]*num
print "您买的 %s 需要支付 %d 元" % (ch_fruit,total_prices)
record="购买%d千克%s"%(num,ch_fruit)#定义购买记录信息
logs(record)#调用log.py中定义的函数logs

运行shopping.py

[root@Python log]# python shopping.py
请输入要买的水果:banana
请输入要买入水果的重量:3
您买的 banana 需要支付 7 元
[root@Python log]# python shopping.py
请输入要买的水果:pear
请输入要买入水果的重量:10
您买的 pear 需要支付 33 元
[root@Python log]# python shopping.py
请输入要买的水果:apple
请输入要买入水果的重量:8
您买的 apple 需要支付 36 元

查看生成日志记录信息:

[root@Python log]# cat shopping.log 
2016-01-27 11:10:47 购买3千克banana
2016-01-27 11:10:53 购买10千克pear
2016-01-27 11:11:02 购买8千克apple
[root@Python log]#

思路:在生产中可以把日志记录模块写到一个文件中,然后在生产的程序中直接导入即可,最后根据需求定义要写入的记录内容