python 通过logging写入日志到文件和控制台的实例


Posted in Python onApril 28, 2018

如下所示:

import logging 
 
# 创建一个logger 
logger = logging.getLogger('mylogger') 
logger.setLevel(logging.DEBUG) 
 
# 创建一个handler,用于写入日志文件 
fh = logging.FileHandler('test.log') 
fh.setLevel(logging.DEBUG) 
 
# 再创建一个handler,用于输出到控制台 
ch = logging.StreamHandler() 
ch.setLevel(logging.DEBUG) 
 
# 定义handler的输出格式 
formatter = logging.Formatter('[%(asctime)s][%(thread)d][%(filename)s][line: %(lineno)d][%(levelname)s] ## %(message)s')
fh.setFormatter(formatter) 
ch.setFormatter(formatter) 
 
# 给logger添加handler 
logger.addHandler(fh) 
logger.addHandler(ch) 
 
# 记录一条日志 
logger.info('foorbar')

关于formatter的配置,采用的是%(<dict key>)s的形式,就是字典的关键字替换。提供的关键字包括:

Format Description
%(name)s Name of the logger (logging channel).
%(levelno)s Numeric logging level for the message (DEBUG, INFO, WARNING, ERROR, CRITICAL).
%(levelname)s Text logging level for the message ('DEBUG', 'INFO', 'WARNING', 'ERROR', 'CRITICAL').
%(pathname)s Full pathname of the source file where the logging call was issued (if available).
%(filename)s Filename portion of pathname.
%(module)s Module (name portion of filename).
%(funcName)s Name of function containing the logging call.
%(lineno)d Source line number where the logging call was issued (if available).
%(created)f Time when the LogRecord was created (as returned by time.time()).
%(relativeCreated)d Time in milliseconds when the LogRecord was created, relative to the time the logging module was loaded.
%(asctime)s Human-readable time when the LogRecord was created. By default this is of the form “2003-07-08 16:49:45,896” (the numbers after the comma are millisecond portion of the time).
%(msecs)d Millisecond portion of the time when the LogRecord was created.
%(thread)d Thread ID (if available).
%(threadName)s Thread name (if available).
%(process)d Process ID (if available).
%(message)s The logged message, computed as msg % args.

以上这篇python 通过logging写入日志到文件和控制台的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python的SQLAlchemy框架使用入门
Apr 29 Python
python从入门到精通(DAY 3)
Dec 20 Python
Python实现的递归神经网络简单示例
Aug 11 Python
Sublime开发python程序的示例代码
Jan 24 Python
opencv python统计及绘制直方图的方法
Jan 21 Python
python使用KNN算法识别手写数字
Apr 25 Python
python调用webservice接口的实现
Jul 12 Python
python实现while循环打印星星的四种形状
Nov 23 Python
Python 输出详细的异常信息(traceback)方式
Apr 08 Python
python中rc1什么意思
Jun 19 Python
Pycharm安装Qt Design快捷工具的详细教程
Nov 18 Python
Python 中 Shutil 模块详情
Nov 11 Python
Python实现合并同一个文件夹下所有PDF文件的方法示例
Apr 28 #Python
用TensorFlow实现多类支持向量机的示例代码
Apr 28 #Python
详谈python在windows中的文件路径问题
Apr 28 #Python
TensorFlow实现随机训练和批量训练的方法
Apr 28 #Python
对python中的logger模块全面讲解
Apr 28 #Python
详解PyTorch批训练及优化器比较
Apr 28 #Python
Python使用matplotlib实现的图像读取、切割裁剪功能示例
Apr 28 #Python
You might like
改德生G88 - 加装等响度低音提升电路
2021/03/02 无线电
PHP 数字左侧自动补0
2008/03/31 PHP
php接口和抽象类使用示例详解
2014/03/02 PHP
PHP全局使用Laravel辅助函数dd
2019/12/26 PHP
很多人都是用下面的js刷新站IP和PV
2008/09/05 Javascript
加载jQuery后$冲突的解决办法
2010/07/09 Javascript
js实现表格字段排序
2014/02/19 Javascript
angularjs 中$apply,$digest,$watch详解
2016/10/13 Javascript
基于JavaScript实现带缩略图的轮播效果
2017/01/12 Javascript
Vue.js开发环境快速搭建教程
2017/03/17 Javascript
使用electron制作满屏心特效的示例代码
2018/11/27 Javascript
socket在egg中的使用实例代码详解
2019/05/30 Javascript
详解python中的json和字典dict
2018/06/22 Python
Python实现提取XML内容并保存到Excel中的方法
2018/09/01 Python
基于Python实现定时自动给微信好友发送天气预报
2018/10/25 Python
python 判断三个数字中的最大值实例代码
2019/07/24 Python
python自动生成model文件过程详解
2019/11/02 Python
在OpenCV里实现条码区域识别的方法示例
2019/12/04 Python
OpenCV Python实现拼图小游戏
2020/03/23 Python
python 发送get请求接口详解
2020/11/17 Python
HTML5 video 事件应用示例
2014/09/11 HTML / CSS
Christys’ Hats官网:英国帽子制造商
2018/11/28 全球购物
保荐人的岗位职责
2013/11/19 职场文书
化学教师教学反思
2014/01/17 职场文书
自荐书范文范例
2014/02/13 职场文书
幼儿教师国培感言
2014/02/19 职场文书
成品库仓管员岗位职责
2014/04/06 职场文书
舞蹈兴趣小组活动总结
2014/07/07 职场文书
王兆力在市委党的群众路线教育实践活动总结大会上的讲话稿
2014/10/25 职场文书
国际贸易实训报告
2014/11/05 职场文书
学生会辞职信
2015/03/02 职场文书
2015年体育教学工作总结
2015/05/20 职场文书
如何用PHP实现分布算法之一致性哈希算法
2021/05/26 PHP
redis击穿 雪崩 穿透超详细解决方案梳理
2022/03/17 Redis
奥特曼十大神器:奥特手镯在榜,第一是贝利亚的神器
2022/03/18 日漫
HTML实现仿Windows桌面主题特效的实现
2022/06/28 HTML / CSS