python中callback_python安装后怎么打开

python中callback_python安装后怎么打开刚接触Python的时候,简单的异常处理已经可以帮助我们解决大多数问题,但是随着逐渐地深入,我们会发现有很多情况下简单的异常处理已经无法解决问题了,如下代码,单纯的打印异常所能提供的信息会非常有限。deffunc1():raiseException(“–func1exception–“)defmain():try:func1()exceptExceptionase:printe…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

刚接触Python的时候,简单的异常处理已经可以帮助我们解决大多数问题,但是随着逐渐地深入,我们会发现有很多情况下简单的异常处理已经无法解决问题了,如下代码,单纯的打印异常所能提供的信息会非常有限。

def func1():

raise Exception(“–func1 exception–“)

def main():

try:

func1()

except Exception as e:

print e

if __name__ == ‘__main__’:

main()

执行后输出如下:

–func1 exception–

通过示例,我们发现普通的打印异常只有很少量的信息(通常是异常的value值),这种情况下我们很难定位在哪块代码出的问题,以及如何出现这种异常。那么到底要如何打印更加详细的信息呢?下面我们就来一一介绍。

sys.exc_info和traceback object

Python程序的traceback信息均来源于一个叫做traceback object的对象,而这个traceback object通常是通过函数sys.exc_info()来获取的,先来看一个例子:

import sys

def func1():

raise NameError(“–func1 exception–“)

def main():

try:

func1()

except Exception as e:

exc_type, exc_value, exc_traceback_obj = sys.exc_info()

print “exc_type: %s” % exc_type

print “exc_value: %s” % exc_value

print “exc_traceback_obj: %s” % exc_traceback_obj

if __name__ == ‘__main__’:

main()

执行后输出如下:

exc_type:

exc_value: –func1 exception–

exc_traceback_obj:

通过以上示例我们可以看出,sys.exc_info()获取了当前处理的exception的相关信息,并返回一个元组,元组的第一个数据是异常的类型(示例是NameError类型),第二个返回值是异常的value值,第三个就是我们要的traceback object.

有了traceback object我们就可以通过traceback module来打印和格式化traceback的相关信息,下面我们就来看下traceback module的相关函数。

traceback module

Python的traceback module提供一整套接口用于提取,格式化和打印Python程序的stack traces信息,下面我们通过例子来详细了解下这些接口:

print_tb

import sys

import traceback

def func1():

raise NameError(“–func1 exception–“)

def main():

try:

func1()

except Exception as e:

exc_type, exc_value, exc_traceback_obj = sys.exc_info()

traceback.print_tb(exc_traceback_obj)

if __name__ == ‘__main__’:

main()

输出:

File “”, line 11, in main

func1()

File “”, line 6, in func1

raise NameError(“–func1 exception–“)

这里我们可以发现打印的异常信息更加详细了,下面我们了解下print_tb的详细信息:

traceback.print_tb(tb[, limit[, file]])

tb: 这个就是traceback object, 是我们通过sys.exc_info获取到的

limit: 这个是限制stack trace层级的,如果不设或者为None,就会打印所有层级的stack trace

file: 这个是设置打印的输出流的,可以为文件,也可以是stdout之类的file-like object。如果不设或为None,则输出到sys.stderr。

print_exception

import sys

import traceback

def func1():

raise NameError(“–func1 exception–“)

def func2():

func1()

def main():

try:

func2()

except Exception as e:

exc_type, exc_value, exc_traceback_obj = sys.exc_info()

traceback.print_exception(exc_type, exc_value, exc_traceback_obj, limit=2, file=sys.stdout)

if __name__ == ‘__main__’:

main()

输出:

Traceback (most recent call last):

File “”, line 13, in main

func2()

File “”, line 9, in func2

func1()

NameError: –func1 exception–

看下定义:

traceback.print_exception(etype, value, tb[, limit[, file]])

跟print_tb相比多了两个参数etype和value,分别是exception type和exception value,加上tb(traceback object),正好是sys.exc_info()返回的三个值

另外,与print_tb相比,打印信息多了开头的”Traceback (most…)”信息以及最后一行的异常类型和value信息

还有一个不同是当异常为SyntaxError时,会有”^”来指示语法错误的位置

print_exc

print_exc是简化版的print_exception, 由于exception type, value和traceback object都可以通过sys.exc_info()获取,因此print_exc()就自动执行exc_info()来帮助获取这三个参数了,也因此这个函数是我们的程序中最常用的,因为它足够简单

import sys

import traceback

def func1():

raise NameError(“–func1 exception–“)

def func2():

func1()

def main():

try:

func2()

except Exception as e:

traceback.print_exc(limit=1, file=sys.stdout)

if __name__ == ‘__main__’:

main()

输出(由于limit=1,因此只有一个层级被打印出来):

Traceback (most recent call last):

File “”, line 13, in main

func2()

NameError: –func1 exception–

定义如下:

traceback.print_exc([limit[, file]])

只有两个参数,够简单

format_exc

import logging

import sys

import traceback

logger = logging.getLogger(“traceback_test”)

def func1():

raise NameError(“–func1 exception–“)

def func2():

func1()

def main():

try:

func2()

except Exception as e:

logger.error(traceback.format_exc(limit=1, file=sys.stdout))

if __name__ == ‘__main__’:

main()

从这个例子可以看出有时候我们想得到的是一个字符串,比如我们想通过logger将异常记录在log里,这个时候就需要format_exc了,这个也是最常用的一个函数,它跟print_exc用法相同,只是不直接打印而是返回了字符串。

traceback module中还有一些其它的函数,但因为并不常用,就不在展开来讲,感兴趣的同学可以看下参考链接中的文档。

获取线程中的异常信息

通常情况下我们无法将多线程中的异常带回主线程,所以也就无法打印线程中的异常,而通过上边学到这些知识,我们可以对线程做如下修改,从而实现捕获线程异常的目的。

以下示例来自weidong的博客文章,稍有修改(见参考链接)

import threading

import traceback

def my_func():

raise BaseException(“thread exception”)

class ExceptionThread(threading.Thread):

def __init__(self, group=None, target=None, name=None, args=(), kwargs=None, verbose=None):

“””

Redirect exceptions of thread to an exception handler.

“””

threading.Thread.__init__(self, group, target, name, args, kwargs, verbose)

if kwargs is None:

kwargs = {}

self._target = target

self._args = args

self._kwargs = kwargs

self._exc = None

def run(self):

try:

if self._target:

self._target()

except BaseException as e:

import sys

self._exc = sys.exc_info()

finally:

#Avoid a refcycle if the thread is running a function with

#an argument that has a member that points to the thread.

del self._target, self._args, self._kwargs

def join(self):

threading.Thread.join(self)

if self._exc:

msg = “Thread ‘%s’ threw an exception: %s” % (self.getName(), self._exc[1])

new_exc = Exception(msg)

raise new_exc.__class__, new_exc, self._exc[2]

t = ExceptionThread(target=my_func, name=’my_thread’)

t.start()

try:

t.join()

except:

traceback.print_exc()

输出如下:

Traceback (most recent call last):

File “/data/code/testcode/thread_exc.py”, line 43, in

t.join()

File “/data/code/testcode/thread_exc.py”, line 23, in run

self._target()

File “/data/code/testcode/thread_exc.py”, line 5, in my_func

raise BaseException(“thread exception”)

Exception: Thread ‘my_thread’ threw an exception: thread exception

这样我们就得到了线程中的异常信息。

参考链接

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/234690.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Node之父发布新项目deno:下一代Node;百度推出没有广告的简单搜索;甲骨文计划砍掉Java序列化功能;丨Q新闻…

    Node之父发布新项目deno:下一代Node;百度推出没有广告的简单搜索;甲骨文计划砍掉Java序列化功能;丨Q新闻…

    2021年6月6日
    183
  • PyCharm – 自动缩进代码 (Auto-Indent Lines)

    PyCharm – 自动缩进代码 (Auto-Indent Lines)PyCharm-自动缩进代码(Auto-IndentLines)1.Ctrl+A全选代码。2.Code->Auto-IndentLines自动缩进快捷键Ctrl+Alt+I。Referenceshttps://yongqiang.blog.csdn.net/

    2025年7月7日
    2
  • 小米网关一二三代的区别【转载】网关,mesh ,zigbee「建议收藏」

    小米网关一二三代的区别【转载】网关,mesh ,zigbee「建议收藏」小米智能家居北京小米科技有限责任公司索要资料  一般一个网关覆盖150平米的房子没什么问题,但是如果设备离网关太远,同时又隔了两三堵墙,中间又没有其它设备,那就会有点问题(zigbee设备每个设备之间是可以桥接信号的,它会自动选取信号最好的路径)。所以,一般一个房子一个网关就够了。如果是大房子,网关最好放房子中间位置,先买一个网关,如果信号不够,再买多一个。下面我们就来简单的介绍一下小米网关一二三代的区别!小米网关一二三代的区别  小米多功能网关一代二代和三代有什么区别?最直观的区别在于小米多功能

    2022年8月11日
    7
  • chrom浏览器flash_flash插件

    chrom浏览器flash_flash插件Flash插件概述Flash插件一款安装于浏览器插件,即AdobeFlashPlayerPlugin,使浏览器得以播放swf文件。通过Flash插件最新版下载可以提升浏览器、视频播放软件对于动画文件的最大兼容性。AdobeFlashPlayer是一种广泛使用、专有的多媒体播放器,AdobeFlashPlayer最初设计目的为播放2维向量动量,但至此之后成为适合开发创造丰富型互联网应用…

    2022年5月31日
    81
  • OpenWrt make menuconfig 构建过程「建议收藏」

    OpenWrt make menuconfig 构建过程「建议收藏」OpenWrtmakemenuconfig构建过程1.课题背景之前在《20190614OpenWrt如何添加驱动以及应用程序谢艺华-遗留问题解答》文档的问题7中,承诺要写一个关于makemenuconfig的构架过程。于是就决定花点时间熟悉一下流程,方便以后的工作。2.分析过程2.1OpenWrt目录下的Makefile分析makemenuconfig的过程也…

    2022年5月12日
    45
  • activity中onResume方法详解[通俗易懂]

    activity中onResume方法详解[通俗易懂]onResume比如做一个音乐播放程序,在播放过程中,突然有电话打进来了,这时系统自动调出电话,而你的音乐播放程序置于后台,触发了onPause方法。当你电话结束后,关闭电话,又自动回到音乐播放程序,此时,触发onResume方法,这时,如果你之前在onPause的时候记录了播放点,就可以在onResume方法里来继续播放。onResume方法是Activity第一次创建时重新加载实例时调用…

    2022年5月6日
    69

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号