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 相关文章推荐
操作Windows注册表的简单的Python程序制作教程
Apr 07 Python
Python3读取文件常用方法实例分析
May 22 Python
Python3解决棋盘覆盖问题的方法示例
Dec 07 Python
python读写LMDB文件的方法
Jul 02 Python
python+opencv实现霍夫变换检测直线
Oct 23 Python
解决Pytorch 训练与测试时爆显存(out of memory)的问题
Aug 20 Python
Python之数据序列化(json、pickle、shelve)详解
Aug 30 Python
Python timeit模块的使用实践
Jan 13 Python
Python如何在DataFrame增加数值
Feb 14 Python
小结Python的反射机制
Sep 28 Python
详解python os.path.exists判断文件或文件夹是否存在
Nov 16 Python
python 6种方法实现单例模式
Dec 15 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 和 COM
2006/10/09 PHP
WordPress开发中用于标题显示的相关函数使用解析
2016/01/07 PHP
PHP+apc+ajax实现的ajax_upload上传进度条代码
2016/01/25 PHP
php实现转换html格式为文本格式的方法
2016/05/16 PHP
PHP实现的链式队列结构示例
2017/09/15 PHP
关于jquery ajax 调用带参数的webservice返回XML数据一个小细节
2012/07/31 Javascript
js操作textarea 常用方法总结
2012/12/03 Javascript
特殊情况下如何获取span里面的值
2014/05/20 Javascript
JavaScript实现获取dom中class的方法
2015/02/09 Javascript
javascript中hasOwnProperty() 方法使用指南
2015/03/09 Javascript
jQuery Dialog 打开时自动聚焦的解决方法(两种方法)
2016/11/24 Javascript
jquery+ajax实现省市区三级联动效果简单示例
2017/01/04 Javascript
javascript设计模式之中介者模式学习笔记
2017/02/15 Javascript
ES6解构赋值的功能与用途实例分析
2017/10/31 Javascript
JS声明对象时属性名加引号与不加引号的问题及解决方法
2018/02/16 Javascript
浅谈vue异步数据影响页面渲染
2019/10/29 Javascript
JQuery表单元素取值赋值方法总结
2020/05/12 jQuery
python实现将英文单词表示的数字转换成阿拉伯数字的方法
2015/07/02 Python
编写Python爬虫抓取暴走漫画上gif图片的实例分享
2016/04/20 Python
Python判断文本中消息重复次数的方法
2016/04/27 Python
python 循环遍历字典元素的简单方法
2016/09/11 Python
Python Unittest自动化单元测试框架详解
2018/04/04 Python
对python中的乘法dot和对应分量相乘multiply详解
2018/11/14 Python
Pycharm 2020年最新激活码(亲测有效)
2020/09/18 Python
15个Pythonic的代码示例(值得收藏)
2020/10/29 Python
python中numpy.empty()函数实例讲解
2021/02/05 Python
详解css3使用transform出现字体模糊的解决办法
2020/10/16 HTML / CSS
英国度假别墅预订:Sykes Cottages
2017/06/12 全球购物
澳大利亚宠物食品和药物在线:Jumbo Pets
2018/03/24 全球购物
表达自我的市场:Society6
2018/08/01 全球购物
艺术家策划的室内设计:Curious Egg
2019/03/06 全球购物
助人为乐表扬信范文
2014/01/14 职场文书
工人先进事迹材料
2014/12/26 职场文书
大学生个人学年总结
2015/02/15 职场文书
2015年个人思想总结
2015/03/09 职场文书
2015年教研组工作总结
2015/05/04 职场文书