Django开发中的日志输出的方法


Posted in Python onJuly 02, 2018

开发环境:Ubuntu16.04+Django 1.11.9+Python2.7

一:使用自定义函数输出日志到log文件:

import time 
def print_log(log): 
   file_obj = open('/tmp/filename.log', 'a+')
   log_time = time.strftime(
    '[%Y-%m-%d %H:%M:%S]',
    time.localtime(
      time.time()))  # 转化时间格式
   file_obj.write("%s\n" % (str(log)))
   file_obj.close()    # 记得close()

这样的在需要输出的时候,调用print_log()就可以输出信息到指定的文件了.缺点是不清楚是哪个文件哪个函数输出的信息更也不知道是来自哪一行输出.

获取到函数信息

获取文件名,文件路径,所在函数名,所在行

# 第二个'#'后面为实测输出结果,Linux也测试过
import sys
import os
import time
def get_function_info():
  print(os.path.basename(sys.argv[0]).split(".")[0])   #不带后缀的所在文件名 # 关于函数
  print (os.path.basename(sys.argv[0]))  


 #带后缀的所在文件名 # 关于函数.py
  print (sys._getframe().f_code.co_filename) 


 # 函数路径 # E:/Pycharm/tcp/关于函数.py
  print (sys._getframe().f_code.co_name)  



# 所在函数名  # get_function_info
  print (sys._getframe().f_lineno)    



 # 所在行   # 23
  
get_function_info()

使用上面的方法可以获取到文件名,路径,函数名,所在行的行号

import sys
import os
import time
def get_function_info():
  file_name = os.path.basename(sys.argv[0]).split(".")[0]    
  os.path.basename(sys.argv[0]) 
  sys._getframe().f_code.co_filename 
  function_name = sys._getframe().f_code.co_name 
  function_num = sys._getframe().f_lineno  
  return file_name,function_name,function_num
  
 def print_log(log): 
   file_obj = open('/tmp/filename.log', 'a+')
   log_time = time.strftime(
    '[%Y-%m-%d %H:%M:%S]',
    time.localtime(
      time.time()))
   file_name,function_name, function_num= get_function_info()
   file_obj.write("%s %s %s [line:%s] log %s\n" % (log_time,file_name, function_name,function_num,str(log)))
   file_obj.close()

这样在理论上是能获取到想得到的信息的.

可是这些在django实际开发使用的时候,因为print_log()是单独定义的函数,在被调用的时候,输出的函数名都是manage.py,行数也是固定的,不满足实际需要的.

二:使用logging:

logging.basicConfig(
level=logging.DEBUG,
format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s: %(message)s',
datefmt='%Y-%m-%d %H:%M:%S', 
 filename='/tmp/filename.log',
filemode='a')

上面我使用的配置信息.具体参数意思如下:

  1. 第一行:日志等级
  2. 第二行:输出格式,message是接收的参数
  3. 第三行:时间格式
  4. 第四行:输出的log文档路径
  5. 第五行:表示追加

如下使用即可.

import logging
logging.debug(log)

logging.debug(log)中log表示需要输出的log信息,这样会输出所有的信息

logging的日志级别:

critical > error > warning > info > debug

所以debug能输出所有的信息,特别是开发阶段,需要所有信息.

format参数中可能用到的格式化信息:

%(filename)s调用日志输出函数的模块的文件名

%(asctime)s  字符串形式的当前时间,有默认格式.

%(lineno)d    调用日志输出函数的语句所在的代码行

%(levelname)s  文本形式的日志级别

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
初步认识Python中的列表与位运算符
Oct 12 Python
Django学习笔记之Class-Based-View
Feb 15 Python
Python数据结构与算法之图结构(Graph)实例分析
Sep 05 Python
python使用pyqt写带界面工具的示例代码
Oct 23 Python
Python随机生成均匀分布在三角形内或者任意多边形内的点
Dec 14 Python
python xpath获取页面注释的方法
Jan 14 Python
windows系统中Python多版本与jupyter notebook使用虚拟环境的过程
May 15 Python
python网络爬虫 Scrapy中selenium用法详解
Sep 28 Python
基于python-pptx库中文文档及使用详解
Feb 14 Python
python3+opencv生成不规则黑白mask实例
Feb 19 Python
详解scrapy内置中间件的顺序
Sep 28 Python
python人工智能human learn绘图可创建机器学习模型
Nov 23 Python
Python中循环后使用list.append()数据被覆盖问题的解决
Jul 01 #Python
Django 连接sql server数据库的方法
Jun 30 #Python
python绘制直线的方法
Jun 30 #Python
Python Grid使用和布局详解
Jun 30 #Python
Python 删除连续出现的指定字符的实例
Jun 29 #Python
使用python语言,比较两个字符串是否相同的实例
Jun 29 #Python
python去除文件中重复的行实例
Jun 29 #Python
You might like
php使用strtotime和date函数判断日期是否有效代码分享
2013/12/25 PHP
ThinkPHP实例化模型的四种方法概述
2014/08/22 PHP
PHP SFTP实现上传下载功能
2017/07/26 PHP
php微信开发之谷歌测距
2018/06/14 PHP
javascript编程起步(第六课)
2007/01/10 Javascript
JavaScript 工具库 Cloudgamer JavaScript Library v0.1 发布
2009/10/29 Javascript
JavaScript中几个重要的属性(this、constructor、prototype)介绍
2013/05/19 Javascript
js 剪切板的用法(clipboardData.setData)与js match函数介绍
2013/11/19 Javascript
Jquery uploadify图片上传插件无法上传的解决方法
2013/12/16 Javascript
用JQuery实现全选与取消的两种简单方法
2014/02/22 Javascript
JavaScript声明变量时为什么要加var关键字
2014/09/29 Javascript
JavaScript计时器用法分析【setTimeout和clearTimeout】
2017/01/18 Javascript
微信小程序中hidden不生效原因的解决办法
2017/04/26 Javascript
JavaScript中运算符规则和隐式类型转换示例详解
2017/09/06 Javascript
JavaScrip数组删除特定元素的几种方法总结
2017/09/06 Javascript
JavaScript 中的 this 简单规则
2017/09/19 Javascript
Jquery实现无缝向上循环滚动列表的特效
2019/02/13 jQuery
jQuery ajax仿Google自动提示SearchSuggess功能示例
2019/03/28 jQuery
从零学python系列之新版本导入httplib模块报ImportError解决方案
2014/05/23 Python
Python决策树和随机森林算法实例详解
2018/01/30 Python
Python Json序列化与反序列化的示例
2018/01/31 Python
浅谈Pandas 排序之后索引的问题
2018/06/07 Python
python Matplotlib底图中鼠标滑过显示隐藏内容的实例代码
2019/07/31 Python
keras 多gpu并行运行案例
2020/06/10 Python
Python并发爬虫常用实现方法解析
2020/11/19 Python
美国蔬菜和植物种子公司:Burpee
2017/02/01 全球购物
SNIDEL官网:日本VIVI杂志人气少女第一品牌
2020/03/12 全球购物
销售行业个人求职自荐信
2013/09/25 职场文书
捐款倡议书范文
2014/02/02 职场文书
幼儿园教学管理制度
2014/02/04 职场文书
助人为乐道德模范事迹材料
2014/08/16 职场文书
2015年团支部工作总结
2015/04/03 职场文书
学雷锋献爱心活动总结
2015/05/11 职场文书
2015法院个人工作总结范文
2015/05/25 职场文书
2016计划生育先进个人事迹材料
2016/02/29 职场文书
Android中View.post和Handler.post的关系
2022/06/05 Java/Android