标签:Django,日志,输出
开发环境: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')
上面我使用的配置信息.具体参数意思如下:
第一行:日志等级
第二行:输出格式,message是接收的参数
第三行:时间格式
第四行:输出的log文档路径
第五行:表示追加
如下使用即可.
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 文本形式的日志级别
来源:http://www.cnblogs.com/shiguangyishiyongbuhui/p/9248365.html
0
投稿
猜你喜欢
- 今天做站时碰到个小问题:ASP正则获取文章内容图片地址,现在将此方法的思路拿出来分享下:Function RegExp_Execu
- 什么是计算属性概念计算属性是vue里面为了简化在模板语法中对响应式属性做计算而存在的什么时候应该使用计算属性根据现有响应式的值得到一个新的值
- 使用python访问mysql,需要一系列安装linux下MySQLdb安装见 Python MySQLdb在Linux下的快速
- 本文主要介绍使用Python调用ADB命令实现实时监控logcat关键字的功能采用多进程,可同时监控多个设备,监控多个关键字。需要配置ADB
- 百度语音对上传的语音要求目前必须是单声道,16K采样率,采样深度可以是16位或者8位的PCM编码。其他编码输出的语音识别不出来。语音的处理技
- 此篇博客学习的api如标题,分别是:current_url获取当前页面的url;page_source 获取当前页面的源码;ti
- 无法装载DLL Microsoft原因: 126(找不到指定的模块)。 U890帐套引入提示:“无法装载 DLL Microsoft提示您请
- 背景最近在学习MIT的分布式课程6.824的过程中,使用Go实现Raft协议时遇到了一些问题。分享出来供大家参考学习,下面话不多说了,来一起
- 1. 准备工作后台服务接口,对书本的增删改查操作2. 弹出窗口进入ElementUi官网, 找到Dialog对话框,可以参考&ldq
- CSS Type set是一款在线字体调整工具。你可以使用它来对字型进行排版调整并实时的看到CSS代码。在下图中,其中,你可以设置文本的字体
- 一定要注重代码规范,按照平时的代码管理,可以将Python代码规范检测分为两种:静态本地检测:可以借助静态检查工具,比如:Flake8,Py
- 1、说明*,nkw表示命名关键字参数,是用户想输入的关键字参数名称,定义方式是在nkw前追加*,2、作用限制调用者传达的参数名称。3、实例#
- 实现流程从摄像头获取视频流,并转换为一帧一帧的图像,然后将图像信息传递给opencv这个工具库处理,返回灰度图像(就像你使用本地静态图片一样
- 年前帮manager 招GUI设计实习生 (PS. 这个实习生职位依然open,欢迎有兴趣的同学来投,邮箱jj.ying [at] hp.c
- 前面介绍了python在ubuntu16.04环境下,python的虚拟环境virtualenv的安装,下面介绍在windows环境下的安装
- 要求:#出租车计费*************************************************************
- 直接奔入主题看下面pywebio程序,实现了Python的简陋在线编辑器from pywebio.input import *from py
- 这篇文章主要介绍了python线程join方法原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋
- 一、问题引出浅拷贝首先看下面代码的执行情况:a = [1, 2, 3]print('a = %s' % a) # a = [
- 由于Access数据库是一种文件型数据库,所以无法跨服务器进行访问。下面我们来介绍一下如何利用SQL Server 的链接服务器,把地理上分