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 动态获取当前运行的类名和函数名的方法
Apr 15 Python
用Python制作简单的钢琴程序的教程
Apr 01 Python
python ansible服务及剧本编写
Dec 29 Python
Django 路由控制的实现
Jul 17 Python
pygame实现俄罗斯方块游戏(AI篇1)
Oct 29 Python
Python函数的默认参数设计示例详解
Dec 01 Python
Python如何使用字符打印照片
Jan 03 Python
Python中文分词库jieba,pkusegwg性能准确度比较
Feb 11 Python
python GUI库图形界面开发之PyQt5浏览器控件QWebEngineView详细使用方法
Feb 26 Python
python实现FTP文件传输的方法(服务器端和客户端)
Mar 20 Python
jupyter notebook远程访问不了的问题解决方法
Jan 11 Python
python开发的自动化运维工具ansible详解
Aug 07 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
使用ThinkPHP+Uploadify实现图片上传功能
2014/06/26 PHP
Thinkphp5.0框架使用模型Model的获取器、修改器、软删除数据操作示例
2019/10/11 PHP
JS网络游戏-(模拟城市webgame)提供的一些例子下载
2007/10/14 Javascript
JavaScript 学习笔记(十六) js事件
2010/02/01 Javascript
JavaScript对象之间的转换 jQuery对象和原声DOM
2011/03/07 Javascript
JS保留两位小数 四舍五入函数的小例子
2013/11/20 Javascript
jquery实现倒计时代码分享
2014/06/13 Javascript
用原生JS获取CLASS对象(很简单实用)
2014/10/15 Javascript
javascript实现C语言经典程序题
2015/11/29 Javascript
当jquery ajax遇上401请求的解决方法
2016/05/19 Javascript
极力推荐一款小巧玲珑的可视化编辑器bootstrap-wysiwyg
2016/05/27 Javascript
第九篇Bootstrap导航菜单创建步骤详解
2016/06/21 Javascript
js仿手机页面文件下拉刷新效果
2016/10/14 Javascript
jQuery插件HighCharts绘制的2D堆柱状图效果示例【附demo源码下载】
2017/03/14 Javascript
vue router使用query和params传参的使用和区别
2017/11/13 Javascript
Vue拖拽组件开发实例详解
2018/05/11 Javascript
微信小程序地图(map)组件点击(tap)获取经纬度的方法
2019/01/10 Javascript
layer.open组件获取弹出层页面变量、函数的实例
2019/09/25 Javascript
[01:02:02]DOTA2上海特级锦标赛A组败者赛 EHOME VS CDEC第二局
2016/02/25 DOTA
[02:37]2018DOTA2亚洲邀请赛赛前采访 VP.no[o]ne心中最强SOLO是谁
2018/04/04 DOTA
Python+Django在windows下的开发环境配置图解
2009/11/11 Python
浅谈Pandas 排序之后索引的问题
2018/06/07 Python
python读取文本中的坐标方法
2018/10/14 Python
Python3安装psycopy2以及遇到问题解决方法
2019/07/03 Python
Python_查看sqlite3表结构,查询语句的示例代码
2019/07/17 Python
python笔记_将循环内容在一行输出的方法
2019/08/08 Python
python通过文本在一个图中画多条线的实例
2020/02/21 Python
Python filter过滤器原理及实例应用
2020/08/18 Python
美国牛仔品牌:True Religion
2018/11/16 全球购物
保密普查工作实施方案
2014/02/25 职场文书
《飞向蓝天的恐龙》教学反思
2014/04/09 职场文书
劳模事迹材料范文
2014/12/24 职场文书
高中军训感想
2015/08/07 职场文书
九年级语文教学反思
2016/03/03 职场文书
开学季:喜迎新生,迎新标语少不了
2019/11/07 职场文书
javascript Number 与 Math对象的介绍
2021/11/17 Javascript