当前位置:首页 > python > 正文内容

python如何判断一段代码运行是否超出一定时间,如果超出则抛出异常?eventlet模块 (eventlet.timeout.Timeout)

root6年前 (2020-10-24)python2382
# -*- encoding: utf-8 -*-"""
@File    : 20200310_python_test.py
@Time    : 2020/3/10 23:29
@Author  : Dontla
@Email   : sxana@qq.com
@Software: PyCharm
"""import timeimport eventlet  # 导入eventlet这个模块eventlet.monkey_patch()  # 必须加这条代码with eventlet.Timeout(2, False):  # 设置超时时间为2秒
    print('这条语句正常执行')
    time.sleep(4)
    print('没有跳过这条输出')print('跳过了输出')123456789101112131415161718

结果:

D:\20191031_tensorflow_yolov3\python\python.exe D:/old/20200310_python_test/20200310_python_test.py
这条语句正常执行
跳过了输出

Process finished with exit code 012345

经检验,一切正常!

也可以套一个try…except,并将Timeout中参数设置为True,这样就能在程序运行时监测异常并在检测到异常后立即对异常进行处理

# -*- encoding: utf-8 -*-"""
@File    : 20200310_python_test.py
@Time    : 2020/3/10 23:29
@Author  : Dontla
@Email   : sxana@qq.com
@Software: PyCharm
"""import timeimport eventlet  # 导入eventlet这个模块eventlet.monkey_patch()  # 必须加这条代码try:
    with eventlet.Timeout(2, False):  # 设置超时时间为2秒
        try:
            time.sleep(4)
            # 该语句正常执行
        except Exception:
            raiseexcept Exception:
    print(Exception)12345678910111213141516171819202122

好像不行哎,没法正常检测到异常

这是正常执行,不会报异常的!!

需要这样,将Timeout()中的参数改为True:

# -*- encoding: utf-8 -*-"""
@File    : 20200310_python_test.py
@Time    : 2020/3/10 23:29
@Author  : Dontla
@Email   : sxana@qq.com
@Software: PyCharm
"""import timeimport eventlet  # 导入eventlet这个模块eventlet.monkey_patch()  # 必须加这条代码try:
    # Dontla 20200421 超时将抛出异常
    with eventlet.Timeout(2, True):  # 设置超时时间为2秒
        time.sleep(4)
    print('程序运行未超时!')except eventlet.timeout.Timeout:
    # except:   # (或,两种都行,注意不能用except Exception,因为Exception是异常基类,我们这个超时异常未包含在它里面)
    print('程序运行超时!')123456789101112131415161718192021

运行结果:

程序运行超时!1
# -*- encoding: utf-8 -*-"""
@File    : 20200310_python_test.py
@Time    : 2020/3/10 23:29
@Author  : Dontla
@Email   : sxana@qq.com
@Software: PyCharm
"""import timeimport eventlet  # 导入eventlet这个模块eventlet.monkey_patch()  # 必须加这条代码try:
    # Dontla 20200421 超时将抛出异常
    with eventlet.Timeout(5, True):  # 设置超时时间为5秒
        time.sleep(4)
    print('程序运行未超时!')except eventlet.timeout.Timeout:
    # except:   # (或,两种都行,注意不嫩用except Exception,因为Exception是异常基类,我们这个超时异常未包含在它里面)
    print('程序运行超时!')123456789101112131415161718192021

运行结果:

程序运行未超时!1

参考文章:python异常类型(Exception只是常规错误的基类)

来自https://blog.csdn.net/Dontla/article/details/104786085


扫描二维码推送至手机访问。

版权声明:本文由一叶知秋发布,如需转载请注明出处。

本文链接:https://www.zhiqiu.top/?id=22

分享给朋友:

相关文章

python 在centos 执行pip安装包时最好提前执行的语句

yum install python-develpip install --upgrade setuptoolspip install --upgrade pi...

selenium控制webdriver  设置请求头。只能设置简单的。自定义和固定的格式无法修改成功

selenium控制webdriver 设置请求头。只能设置简单的。自定义和固定的格式无法修改成功

time selenium webdriver options webdriver.() options.() options.( options.() browser webdriver....

python用requests发送模拟请求忽略https的认证,忽略警告

import warnings warnings.filterwarnings('ignore')在文件头添加忽略警告信息的输出r = requests.get('https://kyfw.12306.cn&#...

python 之optparse模块OptionParser

该模块让python脚本命令能够符合标准的Unix命令例程式每个命令行参数就是由参数名字符串和参数属性组成的。如 -f 或者 file 分别是长短参数名当你将所有的命令行参数都定义好了的时候,我们需要调用parse_args()方法赖际熙a...

python2的pip 不能使用或者使用总是报错

python2的pip 不能使用或者使用总是报错

python2.7   当然可能还有其他情况有的是pip版本升级过高,有的是pip有点问题无法执行pip的命令升级python2的 pip 一定要小心推荐命令:pip install --upgrad...

python进行远程ssh连接的pexpect模块

from pexpect import pxssh s=pxssh.pxssh() s.login(host, user, password) s.sendline(cmd) s.p...