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根据距离和时长计算配速示例
Feb 16 Python
Windows8下安装Python的BeautifulSoup
Jan 22 Python
Python中序列的修改、散列与切片详解
Aug 27 Python
Python tkinter实现的图片移动碰撞动画效果【附源码下载】
Jan 04 Python
新手常见6种的python报错及解决方法
Mar 09 Python
基于python 二维数组及画图的实例详解
Apr 03 Python
Python中几种属性访问的区别与用法详解
Oct 10 Python
Anaconda之conda常用命令介绍(安装、更新、删除)
Oct 06 Python
详解python常用命令行选项与环境变量
Feb 20 Python
浅谈django 重载str 方法
May 19 Python
python 多线程中join()的作用
Oct 29 Python
Python开发.exe小工具的详细步骤
Jan 27 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堆排序实现原理与应用方法
2015/01/03 PHP
PHP生成二维码与识别二维码的方法详解【附源码下载】
2019/03/07 PHP
IE Firefox 使用自定义标签的区别
2009/10/15 Javascript
读jQuery之六 缓存数据功能介绍
2011/06/21 Javascript
JQury slideToggle闪烁问题及解决办法
2011/07/05 Javascript
JS 添加网页桌面快捷方式的代码详细整理
2012/12/27 Javascript
onbeforeunload与onunload事件异同点总结
2013/06/24 Javascript
js实现倒计时时钟的示例代码
2013/12/17 Javascript
jquery mobile界面数据刷新的实现方法
2016/05/28 Javascript
JavaScript组合模式学习要点
2016/08/26 Javascript
JavaScript实现为事件句柄绑定监听函数的方法分析
2017/11/14 Javascript
JS 中可以提升幸福度的小技巧(可以识别更多另类写法)
2018/07/28 Javascript
JS/HTML5游戏常用算法之路径搜索算法 随机迷宫算法详解【普里姆算法】
2018/12/13 Javascript
微信小程序下拉框组件使用方法详解
2018/12/28 Javascript
vue中使用element ui的弹窗与echarts之间的问题详解
2019/10/25 Javascript
[52:41]OG vs IG 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/20 DOTA
复习Python中的字符串知识点
2015/04/14 Python
python验证身份证信息实例代码
2019/05/06 Python
Python上下文管理器类和上下文管理器装饰器contextmanager用法实例分析
2019/11/07 Python
tensorflow自定义激活函数实例
2020/02/04 Python
Python爬虫爬取电影票房数据及图表展示操作示例
2020/03/27 Python
Python脚本实现Zabbix多行日志监控过程解析
2020/08/26 Python
阿拉伯世界最大的电子商务网站:Souq沙特阿拉伯
2016/10/28 全球购物
海信商城:海信电视、科龙空调、容声冰箱官方专卖
2017/02/07 全球购物
IWOOT美国:新奇的小玩意
2018/04/27 全球购物
JBL英国官网:JBL UK
2018/07/04 全球购物
LightInTheBox法国站:中国跨境电商
2020/03/05 全球购物
泰国时尚电商:POMELO Fashion
2020/03/11 全球购物
经理职责范文
2013/11/08 职场文书
教师绩效工资方案
2014/02/01 职场文书
绩效工资实施方案
2014/03/15 职场文书
校园环保标语
2014/06/13 职场文书
白酒营销策划方案
2014/08/17 职场文书
2016年教师党员承诺书范文
2016/03/24 职场文书
redis限流的实际应用
2021/04/24 Redis
详解JavaScript中的执行上下文及调用堆栈
2021/04/29 Javascript