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 selenium鼠标键盘操作(ActionChains)
Apr 12 Python
详解Python中最难理解的点-装饰器
Apr 03 Python
基于python requests库中的代理实例讲解
May 07 Python
python配置grpc环境
Jan 01 Python
python 在指定范围内随机生成不重复的n个数实例
Jan 28 Python
python中数组和矩阵乘法及使用总结(推荐)
May 18 Python
python实现七段数码管和倒计时效果
Nov 23 Python
python实现将两个文件夹合并至另一个文件夹(制作数据集)
Apr 03 Python
Python读取二进制文件代码方法解析
Jun 22 Python
Python结合百度语音识别实现实时翻译软件的实现
Jan 18 Python
详解用Python把PDF转为Word方法总结
Apr 27 Python
pytorch DataLoader的num_workers参数与设置大小详解
May 28 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
GD输出汉字的函数的分析
2006/10/09 PHP
php实现的支持断点续传的文件下载类
2014/09/23 PHP
php制作圆形用户头像的实例_自定义封装类源代码
2017/09/18 PHP
PHP常用字符串函数小结(推荐)
2018/08/05 PHP
PHP chunk_split()函数讲解
2019/02/12 PHP
浅谈Laravel模板实体转义带来的坑
2019/10/22 PHP
(function(){})()的用法与优点
2007/03/11 Javascript
JavaScript入门教程(1) 什么是JS
2009/01/31 Javascript
js实时获取系统当前时间实例代码
2013/06/28 Javascript
nodejs npm package.json中文文档
2014/09/04 NodeJs
JS实现无限级网页折叠菜单(类似树形菜单)效果代码
2015/09/17 Javascript
Javascript中replace()小结
2015/09/30 Javascript
基于MVC4+EasyUI的Web开发框架形成之旅之界面控件的使用
2015/12/16 Javascript
jQuery下拉框的简单应用
2016/06/24 Javascript
Jquery和BigFileUpload实现大文件上传及进度条显示
2016/06/27 Javascript
jQuery ready()和onload的加载耗时分析
2016/09/08 Javascript
利用VUE框架,实现列表分页功能示例代码
2017/01/12 Javascript
ES6扩展运算符用法实例分析
2017/10/31 Javascript
通过实例学习React中事件节流防抖
2019/06/17 Javascript
详解从vue-loader源码分析CSS Scoped的实现
2019/09/23 Javascript
Vue项目vscode 安装eslint插件的方法(代码自动修复)
2020/04/15 Javascript
JS数组Reduce方法功能与用法实例详解
2020/04/29 Javascript
Vue组件间数据传递的方式(3种)
2020/07/13 Javascript
分享8个JavaScript库可更好地处理本地存储
2020/10/12 Javascript
Python模块学习 re 正则表达式
2011/05/19 Python
在Python的Django框架中显示对象子集的方法
2015/07/21 Python
python3 爬取图片的实例代码
2018/11/06 Python
python 实现图片旋转 上下左右 180度旋转的示例
2019/01/24 Python
两个元祖T1=('a', 'b'),T2=('c', 'd')使用匿名函数将其转变成[{'a': 'c'},{'b': 'd'}]的几种方法
2019/03/05 Python
详解pandas如何去掉、过滤数据集中的某些值或者某些行?
2019/05/15 Python
Python+pyftpdlib实现局域网文件互传
2020/08/24 Python
沙特阿拉伯家用电器和电子产品购物网站:Sheta and Saif
2020/04/03 全球购物
同学聚会老师邀请函
2014/01/28 职场文书
机关党员2014全国两会学习心得体会
2014/03/10 职场文书
2014年教研室工作总结
2014/12/06 职场文书
用php如何解决大文件分片上传问题
2021/07/07 PHP