Python当中 如果了解模块 那你就很不错了 可以写一些简单的脚本了,来实现你日常的维护,想学好模块 需要去花实践去用,最近在网上搜到的一些资料加上自己的理解 想做一下自己的笔记


模块:

  1. logging

  2. subprocess

  3. time datetime



logging模块

 python提供了一个标准日志的接口,就是logging模块。日志级别有DEBUG,INFO,WARNING,ERROR,CRITICAL五中。


首选来看看logging简单的使用方法


wKioL1dFU1ijyisGAAAjU7B6F4w317.png


这一看到此图中使用了debug()、info()、warning()、error()、critical()五个方法,这五个方法分别用来记录DEBUG、INFO、WARNING、ERROR、CRITICAL级别的日志。但是你会发现debug()和info()方法没有显示任何信息,这是因为默认的日志级别是ERROR ,所以低于此级别的日志不会记录。你还可能会疑惑输出来的日志怎么这样子?别急,往下看,慢慢来解释。


下面我们看看怎么改 可以改变一下默认的级别

wKioL1dFXSuj5i3ZAAAkSdhF_g0636.png

如图上所示,可以使用basicConfig()方法,修改日志级别,logging.DEBUG,logging.INFO,logging.WARNING,logging.ERROR,logging.CRITICAL分别代表着那五中日志级别。可以看到图中日志级别设为INFO,那么INFO级别以上的日志都会被记录。


下面再看下怎么修改日志的输出格式

wKioL1dFXcmCQDs-AAAx5LvZOp4980.png

查看输出结果

wKioL1dFXeST0kHDAAAW2yet6TQ118.png


这个示例内容可能有点多了,没关系,我们一点一点来。

首先程序中:

log_format = '%(filename)s [%(asctime)s] [%(levelname)s] %(message)s'      

#这条是定义日志格式的一个变量。显示的条目可以是以下内容:

%(levelname):日志级别的名字格式

%(levelno)s:日志级别的数字表示

%(name)s:日志名字

%(funcName)s:函数名字

%(asctime):日志时间,可以使用datefmt去定义时间格式,如上图。

%(pathname):脚本的绝对路径

%(filename):脚本的名字

%(module):模块的名字

%(thread):thread id

%(threadName):线程的名字

logging.basicConfig(format=log_format,datefmt='%Y-%m-%d %H:%M:%S %p',level=logging.DEBUG)   #设置日志输出格式和级别。


上面的示例都是将日志输出到屏幕上,能不能写到一个日志文件中呢?答案当然是肯定的,来看

wKioL1dFYEvQRmkVAAA0RoLPAQA182.png查看结果

wKioL1dFYHbAr69LAAAe9y5tk6M758.png

看了吧,日志的设置都是使用basicConfig()方法,需要注意的是,日志写入文件的默认方式是‘a’,也就是追加,如果想覆盖文件,则使用如上图那样,使用filemode='w'。


结合以上的方法编写一个记录日志到文件 也有时间

#/usr/bin/env python
#_*_coding:utf-8 _*_
import logging

log_filename = 'logging_test.log'
log_format = '%(filename)s [%(asctime)s] [%(levelname)s] %(message)s'
logging.basicConfig(format=log_format,datefmt='%Y-%m-%d %H:%M:%S %p',filename=log_filename,filemode='w',level=logging.DEBUG)
logging.debug('this message should be logged')
logging.info('so should this')
logging.warning('And this,too')
~