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 相关文章推荐
Fabric 应用案例
Aug 28 Python
win10环境下python3.5安装步骤图文教程
Feb 03 Python
python读写json文件的简单实现
Apr 11 Python
python复制列表时[:]和[::]之间有什么区别
Oct 16 Python
pygame游戏之旅 添加游戏界面按键图形
Nov 20 Python
PyTorch的深度学习入门教程之构建神经网络
Jun 27 Python
Python read函数按字节(字符)读取文件的实现
Jul 03 Python
TensorFlow2.X结合OpenCV 实现手势识别功能
Apr 08 Python
解决jupyter notebook显示不全出现框框或者乱码问题
Apr 09 Python
python 将列表里的字典元素合并为一个字典实例
Sep 01 Python
Django-simple-captcha验证码包使用方法详解
Nov 28 Python
python实现模拟器爬取抖音评论数据的示例代码
Jan 06 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/11/12 PHP
php 删除记录实现代码
2009/03/12 PHP
php广告加载类用法实例
2014/09/23 PHP
PHP中iconv函数转码时截断字符问题的解决方法
2015/01/21 PHP
PHP使用FFmpeg获取视频播放总时长与码率等信息
2016/09/13 PHP
详细对比php中类继承和接口继承
2018/10/11 PHP
TP5框架请求响应参数实例分析
2019/10/17 PHP
使用JavaScript实现网页版Pongo设计思路及源代码分享
2014/06/16 Javascript
深入浅析JavaScript面向对象和原型函数
2016/02/06 Javascript
Bootstrap入门书籍之(三)栅格系统
2016/02/17 Javascript
如何让一个json文件显示在表格里【实现代码】
2016/05/09 Javascript
Javascript之String对象详解
2016/06/08 Javascript
JavaScript中数组Array方法详解
2017/02/27 Javascript
Vue.js结合bootstrap实现分页控件
2017/03/10 Javascript
jquery radio 动态控制选中失效问题的解决方法
2018/02/28 jQuery
Vue.js@2.6.10更新内置错误处机制Fundebug同步支持相应错误监控
2019/05/13 Javascript
初学python数组的处理代码
2011/01/04 Python
python subprocess 杀掉全部派生的子进程方法
2017/01/16 Python
Pandas 对Dataframe结构排序的实现方法
2018/04/10 Python
python数字图像处理之骨架提取与分水岭算法
2018/04/27 Python
如何用Python合并lmdb文件
2018/07/02 Python
python3 读取Excel表格中的数据
2018/10/16 Python
Pandas 缺失数据处理的实现
2019/11/04 Python
python+selenium+PhantomJS抓取网页动态加载内容
2020/02/25 Python
关于matplotlib-legend 位置属性 loc 使用说明
2020/05/16 Python
详解python metaclass(元类)
2020/08/13 Python
python根据字典的键来删除元素的方法
2020/08/16 Python
pycharm 代码自动补全的实现方法(图文)
2020/09/18 Python
如何利用Python matplotlib绘制雷达图
2020/12/21 Python
Css3新特性应用之视觉效果实例
2016/12/12 HTML / CSS
学校岗位设置方案
2014/01/16 职场文书
2014年十一国庆节活动方案
2014/09/16 职场文书
思想品德评语大全
2014/12/31 职场文书
2015年度企业工作总结
2015/05/21 职场文书
大学副班长竞选稿
2015/11/21 职场文书
MySQL数据库Innodb 引擎实现mvcc锁
2022/05/06 MySQL