如何在日志库中显示确切的行号(发生错误的地方)
how to display exact line number (where the error has occured) in logging library
在下面的代码中,错误在第 7 行。但是,日志在第 10 行显示错误,其中提到了日志记录。
import logging
import urllib2
logging.basicConfig(filename='example.log',level=logging.DEBUG,format='%(levelname) -10s %(asctime)s %(module)s:%(lineno)s %(funcName)s %(message)s')
def main():
try:
urls = "http://www.simplyhired.com/a/job-detaw/jobkey-67b4efe169eee7b2cf2ed47d49b1845070ea37/rid-racliggzfyjgqwfzrlvnqyjtcserhrri/cjp-3/pub_id-1002"
site = urllib2.urlopen(urls).read()
mathfail = 1/0
except Exception, e:
logging.critical(str(e))
main()
日志中显示以下内容:
CRITICAL 2016-04-08 15:28:47,063 testt:10 main HTTP Error 404: Not Found
我希望它显示发生错误的行号,而不是提到日志记录的行号。它应该显示第 7 行而不是第 10 行
我认为您正在寻找堆栈跟踪
import logging
import urllib2
import traceback
logging.basicConfig(filename='example.log',level=logging.DEBUG,format='%(levelname) -10s %(asctime)s %(module)s:%(lineno)s %(funcName)s %(message)s')
def main():
try:
urls = "http://www.simplyhired.com/a/job-detaw/jobkey-67b4efe169eee7b2cf2ed47d49b1845070ea37/rid-racliggzfyjgqwfzrlvnqyjtcserhrri/cjp-3/pub_id-1002"
site = urllib2.urlopen(urls).read()
mathfail = 1/0
except Exception:
logging.critical(traceback.format_exc())
main()
这给了我预期的输出:
import logging
import urllib2
logging.basicConfig(filename='example.log',level=logging.DEBUG,format='%(levelname) -10s %(asctime)s %(module)s:%(lineno)s %(funcName)s %(message)s')
def main():
try:
urls = "http://www.simplyhired.com/a/job-detaw/jobkey-67b4efe169eee7b2cf2ed47d49b1845070ea37/rid-racliggzfyjgqwfzrlvnqyjtcserhrri/cjp-3/pub_id-1002"
site = urllib2.urlopen(urls).read()
mathfail = 1/0
except Exception, e:
logging.exception(str(e))
main()
日志文件中的输出是:
ERROR 2016-04-08 16:18:35,430 testt:10 main HTTP Error 404: Not Found
Traceback (most recent call last):
File "testt.py", line 7, in main
site = urllib2.urlopen(urls).read()
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 154, in urlopen
return opener.open(url, data, timeout)
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 437, in open
response = meth(req, response)
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 550, in http_response
'http', request, response, code, msg, hdrs)
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 475, in error
return self._call_chain(*args)
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 409, in _call_chain
result = func(*args)
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 558, in http_error_default
raise HTTPError(req.get_full_url(), code, msg, hdrs, fp)
HTTPError: HTTP Error 404: Not Found
在下面的代码中,错误在第 7 行。但是,日志在第 10 行显示错误,其中提到了日志记录。
import logging
import urllib2
logging.basicConfig(filename='example.log',level=logging.DEBUG,format='%(levelname) -10s %(asctime)s %(module)s:%(lineno)s %(funcName)s %(message)s')
def main():
try:
urls = "http://www.simplyhired.com/a/job-detaw/jobkey-67b4efe169eee7b2cf2ed47d49b1845070ea37/rid-racliggzfyjgqwfzrlvnqyjtcserhrri/cjp-3/pub_id-1002"
site = urllib2.urlopen(urls).read()
mathfail = 1/0
except Exception, e:
logging.critical(str(e))
main()
日志中显示以下内容:
CRITICAL 2016-04-08 15:28:47,063 testt:10 main HTTP Error 404: Not Found
我希望它显示发生错误的行号,而不是提到日志记录的行号。它应该显示第 7 行而不是第 10 行
我认为您正在寻找堆栈跟踪
import logging
import urllib2
import traceback
logging.basicConfig(filename='example.log',level=logging.DEBUG,format='%(levelname) -10s %(asctime)s %(module)s:%(lineno)s %(funcName)s %(message)s')
def main():
try:
urls = "http://www.simplyhired.com/a/job-detaw/jobkey-67b4efe169eee7b2cf2ed47d49b1845070ea37/rid-racliggzfyjgqwfzrlvnqyjtcserhrri/cjp-3/pub_id-1002"
site = urllib2.urlopen(urls).read()
mathfail = 1/0
except Exception:
logging.critical(traceback.format_exc())
main()
这给了我预期的输出:
import logging
import urllib2
logging.basicConfig(filename='example.log',level=logging.DEBUG,format='%(levelname) -10s %(asctime)s %(module)s:%(lineno)s %(funcName)s %(message)s')
def main():
try:
urls = "http://www.simplyhired.com/a/job-detaw/jobkey-67b4efe169eee7b2cf2ed47d49b1845070ea37/rid-racliggzfyjgqwfzrlvnqyjtcserhrri/cjp-3/pub_id-1002"
site = urllib2.urlopen(urls).read()
mathfail = 1/0
except Exception, e:
logging.exception(str(e))
main()
日志文件中的输出是:
ERROR 2016-04-08 16:18:35,430 testt:10 main HTTP Error 404: Not Found
Traceback (most recent call last):
File "testt.py", line 7, in main
site = urllib2.urlopen(urls).read()
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 154, in urlopen
return opener.open(url, data, timeout)
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 437, in open
response = meth(req, response)
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 550, in http_response
'http', request, response, code, msg, hdrs)
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 475, in error
return self._call_chain(*args)
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 409, in _call_chain
result = func(*args)
File "/home/deepu/anaconda/lib/python2.7/urllib2.py", line 558, in http_error_default
raise HTTPError(req.get_full_url(), code, msg, hdrs, fp)
HTTPError: HTTP Error 404: Not Found