Python之log的处理方式

配置文件:

 1 #! /usr/bin/env python
 2 # -*- coding: utf-8 -*-
 3 """
 4 logging配置
 5 """
 6
 7 import os
 8 import logging.config
 9
10 # 定义三种日志输出格式 开始
11
12 standard_format = ‘[%(asctime) -s][%(threadName)s:%(thread)d][task_id:%(name)s][%(filename)s:%(lineno)d]‘ 13                   ‘[%(levelname)s][%(message)s]‘
14
15 simple_format = ‘[%(levelname)s][%(asctime)s][%(filename)s:%(lineno)d]%(message)s‘
16
17 id_simple_format = ‘[%(levelname)s][%(asctime)s] %(message)s‘
18
19 # 定义日志输出格式 结束
20
21 logfile_dir = os.path.dirname(os.path.abspath(__file__))  # log文件的目录
22
23 logfile_name = ‘all2.log‘  # log文件名
24
25 # 如果不存在定义的日志目录就创建一个
26 if not os.path.isdir(logfile_dir):
27     os.mkdir(logfile_dir)
28
29 # log文件的全路径
30 logfile_path = os.path.join(logfile_dir, logfile_name)
31
32 # log配置字典
33 LOGGING_DIC = {
34     ‘version‘: 1,
35     ‘disable_existing_loggers‘: False,
36     ‘formatters‘: {
37         ‘standard‘: {
38             ‘format‘: standard_format,
39             ‘datefmt‘: ‘%Y-%m-%d %H:%M:%S‘,
40         },
41         ‘simple‘: {
42             ‘format‘: simple_format
43         },
44     },
45     ‘filters‘: {},
46     ‘handlers‘: {
47         ‘console‘: {
48             ‘level‘: ‘DEBUG‘,
49             ‘class‘: ‘logging.StreamHandler‘,  # 打印到屏幕
50             ‘formatter‘: ‘simple‘
51         },
52         ‘default‘: {
53             ‘level‘: ‘DEBUG‘,
54             ‘class‘: ‘logging.handlers.RotatingFileHandler‘,  # 保存到文件
55             ‘filename‘: logfile_path,  # 日志文件
56             ‘maxBytes‘: 1024*1024*5,  # 日志大小 5M
57             ‘backupCount‘: 5,
58             ‘formatter‘: ‘standard‘,
59             ‘encoding‘: ‘utf-8‘,  # 日志文件的编码,再也不用担心中文log乱码了
60         },
61     },
62     ‘loggers‘: {
63         ‘‘: {
64             ‘handlers‘: [‘default‘, ‘console‘],  # 这里把上面定义的两个handler都加上,即log数据既写入文件又打印到屏幕
65             ‘level‘: ‘DEBUG‘,
66             ‘propagate‘: True,  # 向上(更高level的logger)传递
67         },
68     },
69 }
70 logging.config.dictConfig(LOGGING_DIC)  # 导入上面定义的配置
71 logger = logging.getLogger(__name__)  # 生成一个log实例
72 logger.info(‘It works!‘)  # 记录该文件的运行状态

调用测试文件:

 1 #! /usr/bin/env python
 2 # -*- coding: utf-8 -*-
 3 """
 4 MyLogging Test
 5 """
 6
 7 import time
 8 import logging
 9 from log_demo import my_logging  # 导入自定义的logging配置
10
11 logger = logging.getLogger(__file__)  # 生成logger实例
12
13
14 def demo():
15     logger.debug("start range... time:{}".format(time.time()))
16     logger.info("中文测试开始。。。")
17     for i in range(10):
18         logger.debug("i:{}".format(i))
19         time.sleep(2)
20     else:
21         logger.debug("over range... time:{}".format(time.time()))
22     logger.info("中文测试结束。。。")
23
24 if __name__ == "__main__":
25     demo()
时间: 2024-10-11 22:44:55

Python之log的处理方式的相关文章

Python脚本获取参数的方式

在运维过程中,常常需要自己写脚本,而python往往是最佳的选择.那么怎么获取python脚本的命令行参数呢,例如: python demo.py a b c 怎么获取命令行参数,a,b,c 呢?可以通过sys库里面的argv来实现, 例如: $ cat demo.py #-*- coding: UTF-8 -*- import os import sys def demo(): print sys.argv print len(sys.argv) for i in range(len(sys.

python基础:python扩展包的安装方式

python扩展包有三种安装方式: 1. pip安装方式.python3默认自带pip,无需另外安装:在python2.7版本上默认为easy_install安装工作进行安装,如果需要使用pip安装,需要自行下载安装(可以从http://www.pip-installer.org网站下载). 2. 系统自带的包安装管理工具. 3. 从源代码安装. 使用pip安装:在command命令行中输入:pip install 包名,例如:pip install flask 使用pip安装指定版本:在com

python中执行cmd的方式

目前我使用到的python中执行cmd的方式有三种: 1. 使用os.system("cmd") 这是最简单的一种方法,特点是执行的时候程序会打出cmd在Linux上执行的信息.使用前需要import os. [python] view plain copy print? os.system("ls") 2. 使用Popen模块产生新的process 现在大部分人都喜欢使用Popen.Popen方法不会打印出cmd在linux上执行的信息.的确,Popen非常强大,

利用python 提取log 文件中的关键句子,并进行统计分析

利用python开发了一个提取sim.log 中的各个关键步骤中的时间并进行统计的程序: #!/usr/bin/python2.6 import re,datetime file_name='/home/alzhong/logs/qtat1/R2860.01.13/sim-applycommitrollback-bld1.log' file=open(file_name,'r') acnum=[];time_res=[];lnum=0 def trans_time(time): t1=datet

day2-操作系统,编程语言分类,执行Python程序的两种方式,变量,python的内存管理,

1    什么是操作系统 操作系统位于计算机与应用软件之间,是一个协调,管理,控制计算机硬件资源与软件资源的控制程序 2     为何要有操作系统? 1,控制硬件. 2,把对硬件的复杂的操作封装成优美简单的接口,给用户或者应用程序去使用 注意:一套完整的计算机系统包含三部分 应用程序:比如QQ,暴风影音 操作系统:比如windows linux unix 计算机硬件 强调:我们以后开发的都是应用程序,应用程序无法直接操作硬件,但凡要操作硬件,都是调用操作系统的接口 3 编程语言的分类 1,机器语

操作系统+编程语言的分类+执行python程序的两种方式+变量

1.什么是操作系统? 操作系统就是一个协调\管理\控制计算机硬件资源与软件资源的一个控制程序. 2.为何要操作系统? a.把复杂的硬件操作封装成简单的功能\接口用来给用户或者程序来使用(文件) b.把应用程序对硬件的竞争变得有序 3.如何用操作系统? 一套完整的计算机系统分为3层: 应用程序层 操作系统层 计算机硬件层 编程语言的分类 1.机器语言:直接使用二进制指令去编高于写程序(直接操作硬件) 优点:计算机无障碍理解,运行效率高. 缺点:开发效率低 2.汇编语言:使用英文标签代替二进制指令去

python 中特殊方法简写方式

##python 中特殊方法简写方式 class Test: __call__ = lambda *args: args[1] * 2 #这里需要注意lambda的参数 会默认将实例self 加进去 __str__ = lambda self: 'that`s useful...%s' % self.__class__.__name__ t = Test() print(t) print(t(10)) 原文地址:https://www.cnblogs.com/alplf123/p/1029388

python 堡垒机续-----终端方式

第一步:环境准备 堡垒机服务器:192.168.1.1 后端服务器1:192.168.1.2 后端服务器2:192.168.1.3 堡垒机安装paramiko 版本:paramiko-1.16.0 堡垒机python版本:Python 2.7.7   第二步:编写menu.py文件,实现类似菜单功能 #!/usr/bin/env python # encoding: utf-8 # @author: eddy # @contact: [email protected] # @site: http

利用python 提取log 文件里的关键句子,并进行统计分析

利用python开发了一个提取sim.log 中的各个关键步骤中的时间并进行统计的程序: #!/usr/bin/python2.6 import re,datetime file_name='/home/alzhong/logs/qtat1/R2860.01.13/sim-applycommitrollback-bld1.log' file=open(file_name,'r') acnum=[];time_res=[];lnum=0 def trans_time(time): t1=datet