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中的MongoDB基本操作:连接、查询实例
Feb 13 Python
利用Python3分析sitemap.xml并抓取导出全站链接详解
Jul 04 Python
python队列Queue的详解
May 10 Python
Python中的 is 和 == 以及字符串驻留机制详解
Jun 28 Python
全面了解django的缓存机制及使用方法
Jul 22 Python
Python正则表达式急速入门(小结)
Dec 16 Python
Python实现序列化及csv文件读取
Jan 19 Python
浅谈django 重载str 方法
May 19 Python
Tensorflow加载Vgg预训练模型操作
May 26 Python
pycharm 多行批量缩进和反向缩进快捷键介绍
Jan 15 Python
Python基于argparse与ConfigParser库进行入参解析与ini parser
Feb 02 Python
Python人工智能之混合高斯模型运动目标检测详解分析
Nov 07 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伪静态页面函数附使用方法
2008/06/20 PHP
Laravel 实现关系模型取出需要的字段
2019/10/10 PHP
Laravel 手动开关 Eloquent 修改器的操作方法
2019/12/30 PHP
分享精心挑选的12款优秀jQuery Ajax分页插件和教程
2012/08/09 Javascript
js给onclick事件赋值,动态传参数实例解说
2013/03/28 Javascript
纯Javascript实现Windows 8 Metro风格实现
2013/10/15 Javascript
JS 实现BASE64_ENCODE和BASE64_DECODE(实例代码)
2013/11/13 Javascript
javascript生成随机数的方法
2014/05/16 Javascript
jquery网页回到顶部效果(图标渐隐,自写)
2014/06/16 Javascript
jquery获取checkbox的值并post提交
2015/01/14 Javascript
jquery实现简单的无缝滚动
2015/04/15 Javascript
利用JS提交表单的几种方法和验证(必看篇)
2016/09/17 Javascript
jquery事件绑定解绑机制源码解析
2016/09/19 Javascript
jQuery EasyUI右键菜单实现关闭标签/选项卡
2016/10/10 Javascript
vue2.0开发实践总结之疑难篇
2016/12/07 Javascript
vue动态组件实现选项卡切换效果
2017/03/08 Javascript
axios基本入门用法教程
2017/03/25 Javascript
jQuery实现的手风琴侧边菜单效果
2017/03/29 jQuery
详解nodejs微信公众号开发——3.封装消息响应模块
2017/04/10 NodeJs
vue如何使用 Slot 分发内容实例详解
2017/09/05 Javascript
微信小程序实现即时通信聊天功能的实例代码
2018/08/17 Javascript
如何基于vue-cli3.0构建功能完善的移动端架子
2019/04/24 Javascript
js中的this的指向问题详解
2019/08/29 Javascript
解决layer.open后laydate失效的问题
2019/09/06 Javascript
VUE 单页面使用 echart 窗口变化时的用法
2020/07/30 Javascript
基于javascript的无缝滚动动画1
2020/08/07 Javascript
python写入已存在的excel数据实例
2018/05/03 Python
python Django 创建应用过程图示详解
2019/07/29 Python
Python对Excel按列值筛选并拆分表格到多个文件的代码
2019/11/05 Python
python线性插值解析
2020/07/05 Python
玉兰油美国官网:OLAY美国
2018/10/25 全球购物
房地产促销活动方案
2014/03/01 职场文书
中学生爱国演讲稿
2014/09/05 职场文书
大型主题婚礼活动策划方案
2014/09/15 职场文书
大国崛起英国观后感
2015/06/02 职场文书
如何开启Apache,Nginx和IIS服务器的GZIP压缩功能
2022/04/29 Servers