python异常和超时处理_详解python中自定义超时异常的几种方法

详解python中自定义超时异常的几种方法

来源:中文源码网    浏览: 次    日期:2019年11月5日

【下载文档:  详解python中自定义超时异常的几种方法.txt 】

(友情提示:右键点上行txt文档名->目标另存为)

详解python中自定义超时异常的几种方法最近在项目中调用第三方接口时候,经常会出现请求超时的情况,或者参数的问题导致调用异代码异常。针对超时异常,查询了python 相关文档,没有并发现完善的包来根据用户自定义的时间来抛出超时异常的模块。所以自己干脆自己来实现一个自定义的超时异常。目前找到了两种方式来实现超时异常的功能(signal.alarm()、threading实现超时异常)方法1 thread + time 原理:将要调用的功能函数放入子线程,通过设定子线程的阻塞时间,超时则主线程并不会等待子线程的执行。主线程退出,子线程就不存在了。核心就是在程序中添加 join()方法,用于等待线程结束。join()的作用是,在子线程完成运行之前,这个子线程的父线程将会被一直阻塞.

# coding=utf-8

import threading

import time

def myFunc():

time.sleep(4)

print("myFunc执行了")

if __name__ == '__main__':

t = threading.Thread(target=myFunc)

t.setDaemon(True)

t.start() t.join(2)

print("it's over")执行结果:

it's over

可以看出,当主线程执行到2秒时候,结束退出。子线程还没有结束,没有执行完及被强制退出

# coding=utf-8

import threading

import time

def myFunc():

time.sleep(1)

print("myFunc执行了")

if __name__ == '__main__':

t = threading.Thread(target=myFunc)

t.setDaemon(True)

t.start() t.join(2)

print("it's over")显示结果:

myFunc执行了

it's over

可以看出,子线程结束时,用时1秒,没有超过主线程设定的3秒,所以主线程与子线程都被执行了

方法 2 signal.alarm() ,注意两点:一是signal信号机制要在linux上才能运行; 二是signal信号在主线程中才会会起作用

import signal

import time# Define signal handler function

def myHandler(signum, frame):

exit("TimeoutError")def test_fun():

# time.sleep(3)

int("afsdf")

a = 2 + 3

return aif __name__ == '__main__':

try:

signal.signal(signal.SIGALRM, myHandler)

signal.alarm(2)

test = test_fun()

print(test)

signal.alarm(0)

except Exception as ret:

print("msg:", ret)执行结果:

当 time.sleep(3) 时,会抛出TimeoutError的异常

当 test_fun 里面出现 int("afsdf")时, 会抛出 ValueError("invalid literal for int() with base 10: 'afsdf'",))

当test_fun函数执行的时间小于2 秒时,就会返回函数对应的值

方法3 带有返回值的超时异常,可以通过创建thread类的方式来进行捕捉

import threading

import sys

import time

class Dispacher(threading.Thread):

def __init__(self, fun, args):

threading.Thread.__init__(self)

self.setDaemon(True)

self.result = None

self.error = None

self.fun = fun

self.args = args self.start() def run(self):

try:

self.result = self.fun(self.args)

except:

self.error = sys.exc_info()

def test_fun(i):

# time.sleep(4)

a = i*i

# b

return a

def main_fun():

c = Dispacher(test_fun, 2)

c.join(2) if c.isAlive():

return "TimeOutError"

elif c.error:

return c.error[1]

t = c.result

return tif __name__ == '__main__':

fun = main_fun()

print(fun)显示结果:

test_fun 执行时间大于设置的2秒时,会抛出TimeOutError

test_fun 执行时间小于设置的2秒时,并且函数正常执行时,显示:4

test_fun 里面出现比如 “b” 时,会抛出 global name 'b' is not defined 的异常以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持中文源码网。

亲,试试微信扫码分享本页! *^_^*

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`urlopen`是Python标准库用于打开URL的函数。在Python3,它可以通过`urllib.request.urlopen()`来调用。 如果你遇到了`urlopen`报错的问题,以下是一些可能的解决方法: 1. 检查URL是否正确:首先确保你要打开的URL是正确的。如果URL不存在或无法访问,那么`urlopen`函数将会报错。 2. 检查网络连接:如果你的网络连接不稳定或断,那么`urlopen`函数也会报错。确保你的网络连接正常。 3. 添加User-Agent:有些网站需要在请求头添加User-Agent才能访问。你可以通过在`urllib.request.Request`添加headers参数来添加User-Agent。示例代码如下: ```python import urllib.request url = "http://www.example.com" req = urllib.request.Request(url, headers={'User-Agent': 'Mozilla/5.0'}) response = urllib.request.urlopen(req) ``` 4. 添加超时时间:如果请求时间过长,那么`urlopen`函数也会报错。你可以通过在`urlopen`函数添加timeout参数来设置超时时间。示例代码如下: ```python import urllib.request url = "http://www.example.com" response = urllib.request.urlopen(url, timeout=5) ``` 5. 检查代理设置:如果你使用了代理服务器来访问网站,那么请确保代理设置正确。你可以通过在`urllib.request.ProxyHandler`指定代理服务器来设置代理。示例代码如下: ```python import urllib.request proxy_handler = urllib.request.ProxyHandler({'http': 'http://www.example.com:8080/'}) opener = urllib.request.build_opener(proxy_handler) response = opener.open('http://www.example.com') ``` 希望以上方法能帮助你解决`urlopen`报错的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值