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中使用tarfile压缩、解压tar归档文件示例
Apr 05 Python
python编写爬虫小程序
May 14 Python
Python编程之属性和方法实例详解
May 19 Python
Python输出9*9乘法表的方法
May 25 Python
简述Python中的进程、线程、协程
Mar 18 Python
python XlsxWriter模块创建aexcel表格的实例讲解
May 03 Python
使用pytorch进行图像的顺序读取方法
Jul 27 Python
python3.4爬虫demo
Jan 22 Python
对Python生成汉字字库文字,以及转换为文字图片的实例详解
Jan 29 Python
Python底层封装实现方法详解
Jan 22 Python
Django 实现jwt认证的示例
Apr 30 Python
pytorch 权重weight 与 梯度grad 可视化操作
Jun 05 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
咖啡店都有些什么常规豆子呢?有什么风味在里面
2021/03/04 咖啡文化
PHP安全配置
2006/10/09 PHP
PHPMailer 中文使用说明小结
2010/01/22 PHP
PHP高并发和大流量解决方案整理
2021/03/09 PHP
不错的asp中显示新闻的功能
2006/10/13 Javascript
IE innerHTML,outerHTML所引起的问题
2009/06/04 Javascript
为radio类型的INPUT添加客户端脚本(附加实现JS来禁用onClick事件思路代码)
2010/11/11 Javascript
Seajs 简易文档 提供简单、极致的模块化开发体验
2016/04/13 Javascript
javascript淘宝主图放大镜功能
2016/10/20 Javascript
AngularJS实现ajax请求的方法
2016/11/22 Javascript
Bootstrap框架实现广告轮播效果
2016/11/28 Javascript
javascript中的深复制详解及实例分析
2016/12/29 Javascript
分享一个精简的vue.js 图片lazyload插件实例
2017/03/13 Javascript
JS对象序列化成json数据和json数据转化为JS对象的代码
2017/08/23 Javascript
JS数组去重常用方法实例小结【4种方法】
2018/05/28 Javascript
VUE2.0+ElementUI2.0表格el-table实现表头扩展el-tooltip
2018/11/30 Javascript
详解vue beforeEach 死循环问题解决方法
2020/02/25 Javascript
vue实现学生信息管理系统
2020/05/30 Javascript
[48:47]VGJ.S vs NB 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
Python+matplotlib实现计算两个信号的交叉谱密度实例
2018/01/08 Python
python 输入一个数n,求n个数求乘或求和的实例
2018/11/13 Python
python基于C/S模式实现聊天室功能
2019/01/09 Python
python字符串分割及字符串的一些常规方法
2019/07/24 Python
python requests证书问题解决
2019/09/05 Python
Django配置文件代码说明
2019/12/04 Python
Python迭代器Iterable判断方法解析
2020/03/16 Python
CSS3基础(RGBa、text-shadow、box-shadow、border-radius)
2012/11/13 HTML / CSS
CSS3 滤镜 webkit-filter详细介绍及使用方法
2012/12/27 HTML / CSS
李维斯德国官方网上商店:Levi’s德国
2016/09/10 全球购物
教师党员思想汇报
2014/01/06 职场文书
入党推优材料
2014/06/02 职场文书
广播体操口号
2014/06/18 职场文书
银行授权委托书样本
2014/10/13 职场文书
提档介绍信范文
2015/10/22 职场文书
2016大学生暑期三下乡心得体会
2016/01/23 职场文书
使用pandas或numpy处理数据中的空值(np.isnan()/pd.isnull())
2021/05/14 Python