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获取apk文件URL地址实例
Nov 01 Python
python将xml xsl文件生成html文件存储示例讲解
Dec 03 Python
Python实现网站文件的全备份和差异备份
Nov 30 Python
Python实现计算最小编辑距离
Mar 17 Python
Python使用Tkinter实现机器人走迷宫
Jan 22 Python
python实现维吉尼亚加密法
Mar 20 Python
Python多继承以及MRO顺序的使用
Nov 11 Python
Python中类似于jquery的pyquery库用法分析
Dec 02 Python
opencv-python 读取图像并转换颜色空间实例
Dec 09 Python
Mac PyCharm中的.gitignore 安装设置教程
Apr 16 Python
Python Switch Case三种实现方法代码实例
Jun 18 Python
Python3爬虫里关于Splash负载均衡配置详解
Jul 10 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
这东西价格,可以买几台TECSUN S-2000
2021/03/02 无线电
ThinkPHP采用模块和操作分析
2011/04/18 PHP
php简单开启gzip压缩方法(zlib.output_compression)
2013/04/13 PHP
javascript multibox 全选
2009/03/22 Javascript
jMessageBox 基于jQuery的窗口插件
2009/12/09 Javascript
escape编码与unescape解码汉字出现乱码的解决方法
2014/07/02 Javascript
在Ubuntu系统上安装Ghost博客平台的教程
2015/06/17 Javascript
jquery判断iPhone、Android设备类型
2016/09/14 Javascript
jQuery序列化表单成对象的简单实现
2016/11/29 Javascript
Bootstrap的popover(弹出框)在append后弹不出(失效)
2017/02/27 Javascript
详解Windows下安装Nodejs步骤
2017/05/18 NodeJs
深入浅析Vue不同场景下组件间的数据交流
2017/08/15 Javascript
Vue-router的使用和出现空白页,路由对象属性详解
2018/09/03 Javascript
微信小程序websocket实现即时聊天功能
2019/05/21 Javascript
vue相关配置文件详解及多环境配置详细步骤
2020/05/19 Javascript
二种python发送邮件实例讲解(python发邮件附件可以使用email模块实现)
2013/12/03 Python
Python中的rjust()方法使用详解
2015/05/19 Python
详解Python的collections模块中的deque双端队列结构
2016/07/07 Python
mac下给python3安装requests库和scrapy库的实例
2018/06/13 Python
python实现自动解数独小程序
2019/01/21 Python
Python qqbot 实现qq机器人的示例代码
2019/07/11 Python
python 解决flask uwsgi 获取不到全局变量的问题
2019/12/22 Python
为什么python比较流行
2020/06/19 Python
python os模块在系统管理中的应用
2020/06/22 Python
django rest framework使用django-filter用法
2020/07/15 Python
Python实现对word文档添加密码去除密码的示例代码
2020/12/29 Python
营业员实习自我鉴定
2013/12/07 职场文书
《海伦?凯勒》教学反思
2014/04/17 职场文书
优秀党员学习焦裕禄精神思想汇报范文
2014/09/10 职场文书
2015年专项整治工作总结
2015/04/03 职场文书
陈斌强事迹观后感
2015/06/17 职场文书
小学中队委竞选稿
2015/11/20 职场文书
执行力心得体会范文
2016/01/11 职场文书
Python基础之元类详解
2021/04/29 Python
Oracle表空间与权限的深入讲解
2021/11/17 Oracle
shell进度条追踪指令执行时间的场景分析
2022/06/16 Servers