1、打印到控制台

# -*- coding: UTF-8 -*-

import logging

def logFileTest():
logging.debug('This is debug')
logging.warning('This is warning message')
logging.info('This is info') logFileTest()

  运行结果

WARNING:root:This is warning message

  PS : 只有 logging.warning() 能打印输出到控制台,因为默认设置的等级是 warning

2、配置默认等级后,打印到控制台

# -*- coding: UTF-8 -*-

import logging

def logBasicConfig():
logging.basicConfig(level=logging.DEBUG)
logging.debug('This is debug')
logging.warning('This is warning message')
logging.info('This is info') logBasicConfig()

  运行结果

DEBUG:root:This is debug
WARNING:root:This is warning message
INFO:root:This is info

  PS : 日志级别: debug < info < warning < error < critical

3、保存到日志文件中,通过 logging.basicConfig() 设置

# -*- coding: UTF-8 -*-

import logging

def saveToLogFile():
logging.basicConfig(
filename = 'saveMessage.log', #保存文件路径
filemode = 'a',#保存方式,有 w 和 a 模式,默认不写为追加 a 模式
format = '%(asctime)s - %(pathname)s[line:%(lineno)d] - %(levelname)s: %(message)s' #日志格式
)
logging.warning('This is warning') saveToLogFile()

  运行结果

2019-08-27 14:00:58,463 - D:\E_DISK\product\eclipse\logFileDemo\src\com\logFileDemo.py[line:24] - WARNING: This is warning

  PS : 这是 saveMessage.log 文件中生成的日志信息

       如果在 logging.basicConfig() 设置 filename 和 filemode,则只会保存 log 到文件,不会输出到控制台

4、实现info信息记录到文件,error信息记录文件并在屏幕上输出,且实现日志回滚

保存10个文件,每个文件大小为1024*1024

需要注意该函数在一个工程中只能调用一次,否则写入信息会增加,比如调用两次该函数后log.info('aaa')文件中会有两次

因此我写了一个log = LogConfig.log()其他类使用时,用该log就行,有点像单例模式

import logging.handlers
import os class LogConfig:
def __init__(self):
pass # DEBUG,INFO,NOTICE,WARNING,ERROR,CRITICAL,ALERT,EMERGENCY
# only call one @staticmethod
def log(log_name='logs/log.log', log_flag=True,
max_bytes=1024 * 1024, backup_count=10): path = os.path.split(log_name)[0]
if not os.path.isdir(path) and path != '':
os.makedirs(path)
log_handler = logging.getLogger(log_name)
if log_flag:
# write log above info
log_handler.setLevel(logging.INFO)
else:
# write log above error
log_handler.setLevel(logging.ERROR)
stream_handler = logging.StreamHandler()
# is or not show to cmd console
stream_handler.setLevel(logging.WARN)
log_handler.addHandler(stream_handler) rollback_handler = logging.handlers.RotatingFileHandler(log_name,
maxBytes=max_bytes,
backupCount=backup_count)
log_format = logging.Formatter(
'[%(asctime)s][%(levelname)s]%(message)s')
rollback_handler.setFormatter(log_format)
rollback_handler.setLevel(logging.INFO)
log_handler.addHandler(rollback_handler)
return log_handler log = LogConfig.log() if __name__ == '__main__':
log.info('')
log.error('')

Python 记录日志文件的更多相关文章

  1. python 记录日志logging

    在项目开发中,往往要记录日志文件.用python记录日志有两种方式: 1.利用python 自带的logging库,例如: # -*- coding: utf-8 -*- import osimpor ...

  2. Python读写文件

    Python读写文件1.open使用open打开文件后一定要记得调用文件对象的close()方法.比如可以用try/finally语句来确保最后能关闭文件. file_object = open('t ...

  3. python计算文件的md5值

    前言 最近要开发一个基于python的合并文件夹/目录的程序,本来的想法是基于修改时间的比较,即判断文件有没有改变,比较两个文件的修改时间即可.这个想法在windows的pc端下测试没有问题. 但是当 ...

  4. python操作文件案例二则

    前言 python 对于文件及文件夹的操作. 涉及到 遍历文件夹下所有文件 ,文件的读写和操作 等等. 代码一 作用:查找文件夹下(包括子文件夹)下所有文件的名字,找出 名字中含有中文或者空格的文件 ...

  5. Python :open文件操作,配合read()使用!

    python:open/文件操作 open/文件操作f=open('/tmp/hello','w') #open(路径+文件名,读写模式) 如何打开文件 handle=open(file_name,a ...

  6. python学习 文件操作

    一.python打开文件 #=====================python 文件打开方式 open()===================== # open(fileName,type) t ...

  7. Python之文件读写

    本节内容: I/O操作概述 文件读写实现原理与操作步骤 文件打开模式 Python文件操作步骤示例 Python文件读取相关方法 文件读写与字符编码 一.I/O操作概述 I/O在计算机中是指Input ...

  8. python 遍历文件夹 文件

    python 遍历文件夹 文件   import os import os.path rootdir = "d:\data" # 指明被遍历的文件夹 for parent,dirn ...

  9. python检测文件的MD5值

    python检测文件的MD5值MD5(单向散列算法)的全称是Message-Digest Algorithm 5(信息-摘要算法),经MD2.MD3和MD4发展而来.MD5算法的使用不需要支付任何版权 ...

随机推荐

  1. python基础:如何使用python pandas将DataFrame转换为dict

    之前在知乎上看到有网友提问,如何将DataFrame转换为dict,专门研究了一下,pandas在0.21.0版本中是提供了这个方法的.下面一起学习一下,通过调用help方法,该方法只需传入一个参数, ...

  2. D - A Game with Traps-- codeforces 1260D A

    题目大意: 一共有m个士兵,k个陷阱,时间为t,一个首领,这个首领需要在t时间内尽可能多的将士兵带到boos的面前, 第二行是每个士兵的灵敏度. 紧接着是k个陷阱,每个陷阱有l,,r,,d组成,l代表 ...

  3. 忍不住还是手写了一遍博客的css

    F12边调边改,的一点一点撸出来这个效果.感觉已经可以了.日历感觉没什么用直接隐藏了.

  4. mybatis源码配置文件解析之二:解析settings标签

    在前边的博客中分析了mybatis解析properties标签,<mybatis源码配置文件解析之一:解析properties标签>.下面来看解析settings标签的过程. 一.概述 在 ...

  5. ATmega328P定时器详解

    写这篇文章,纯粹是想为博客拉点点击量.在博客园,游客访问好像是不计入阅读量的,而作为一个十八线博主,注册用户的访问应该以搜索引擎为主,博客园首页为次,个位数的粉丝就别谈了. 所以,希望各位从搜索引擎点 ...

  6. 【认证与授权】2、基于session的认证方式

    这一篇将通过一个简单的web项目实现基于Session的认证授权方式,也是以往传统项目的做法. 先来复习一下流程 用户认证通过以后,在服务端生成用户相关的数据保存在当前会话(Session)中,发给客 ...

  7. shll脚本常用格式和规则使用

    shll脚本格式和规则 脚本文件必须已 .sh 结尾(yuan.sh) 脚本第一行必须是:#!/bin/bash 激活脚本的二种方式(sh yuan.sh)(给脚本X权限,以绝对路径执行脚本) 逻辑与 ...

  8. Windows系统安装最新版本RabbitMQ3.8.3及报错解决

    今天想安装下RabbitMQ写几个用例看下,发现最新的安装包有些问题,不能直接安装使用,遇到一些问题,记录一下解决办法. 下载安装包 因为RabbitMQ是Erlang编写,安装时,需要先安装Erla ...

  9. PHP实现MySQL并发查询

    一般的,一个看似很简单的页面,一次http请求后,到达服务端,穿过Cache层,落到后台后,实际可能会有很多很多的数据查询逻辑!而这些查询实际是不相互依赖的,也即可以同时查询.比如各种用户信息,用户的 ...

  10. 在Spring Boot中加载初始化数据

    文章目录 依赖条件 data.sql文件 schema.sql 文件 @sql注解 @SqlConfig 注解 在Spring Boot中加载初始化数据 在Spring Boot中,Spring Bo ...