Datawhale组队学习 -- Task 3: Python的异常类型总结和捕获语句

异常就是运行期检测到的错误。计算机语言针对可能出现的错误定义了异常类型,某种错误引发对应的异常时,异常处理程序将被启动,从而恢复程序的正常运行。

1. Python 标准异常总结

  • BaseException:所有异常的 基类
  • Exception:常规异常的 基类
  • StandardError:所有的内建标准异常的基类
  • ArithmeticError:所有数值计算异常的基类
  • FloatingPointError:浮点计算异常
  • OverflowError:数值运算超出最大限制
  • ZeroDivisionError:除数为零
  • AssertionError:断言语句(assert)失败
  • AttributeError:尝试访问未知的对象属性
  • EOFError:没有内建输入,到达EOF标记
  • EnvironmentError:操作系统异常的基类
  • IOError:输入/输出操作失败
  • OSError:操作系统产生的异常(例如打开一个不存在的文件)
  • WindowsError:系统调用失败
  • ImportError:导入模块失败的时候
  • KeyboardInterrupt:用户中断执行
  • LookupError:无效数据查询的基类
  • IndexError:索引超出序列的范围
  • KeyError:字典中查找一个不存在的关键字
  • MemoryError:内存溢出(可通过删除对象释放内存)
  • NameError:尝试访问一个不存在的变量
  • UnboundLocalError:访问未初始化的本地变量
  • ReferenceError:弱引用试图访问已经垃圾回收了的对象
  • RuntimeError:一般的运行时异常
  • NotImplementedError:尚未实现的方法
  • SyntaxError:语法错误导致的异常
  • IndentationError:缩进错误导致的异常
  • TabError:Tab和空格混用
  • SystemError:一般的解释器系统异常
  • TypeError:不同类型间的无效操作
  • ValueError:传入无效的参数
  • UnicodeError:Unicode相关的异常
  • UnicodeDecodeError:Unicode解码时的异常
  • UnicodeEncodeError:Unicode编码错误导致的异常
  • UnicodeTranslateError:Unicode转换错误导致的异常

异常体系内部有层次关系,Python异常体系中的部分关系如下所示:

 


2. Python标准警告总结

  • Warning:警告的基类
  • DeprecationWarning:关于被弃用的特征的警告
  • FutureWarning:关于构造将来语义会有改变的警告
  • UserWarning:用户代码生成的警告
  • PendingDeprecationWarning:关于特性将会被废弃的警告
  • RuntimeWarning:可疑的运行时行为(runtime behavior)的警告
  • SyntaxWarning:可疑语法的警告
  • ImportWarning:用于在导入模块过程中触发的警告
  • UnicodeWarning:与Unicode相关的警告
  • BytesWarning:与字节或字节码相关的警告
  • ResourceWarning:与资源使用相关的警告

3. try - except 语句

  • 概念
    • try 语句按照如下方式工作:
      • 首先,执行try子句(在关键字try和关键字except之间的语句)
      • 如果没有异常发生,忽略except子句,try子句执行后结束。
      • 如果在执行try子句的过程中发生了异常,那么try子句余下的部分将被忽略。如果异常的类型和except之后的名称相符,那么对应的except子句将被执行。最后执行try语句之后的代码。
      • 如果一个异常没有与任何的except匹配,那么这个异常将会传递给上层的try中。
  • 代码
# 单个except并不输出具体错误信息
try:
    f = open('test.txt')
    print(f.read())
    f.close()
except OSError:
    print('打开文件出错')

# 多行except并as了错误信息error
# 一个try语句可能包含多个except子句,分别来处理不同的特定的异常。最多只有一个分支会被执行。
try:
    int("abc")
    s = 1 + '1'
    f = open('test.txt')
    print(f.read())
    f.close()
except OSError as error:
    print('打开文件出错\n原因是:' + str(error))
except TypeError as error:
    print('类型出错\n原因是:' + str(error))
except ValueError as error:
    print('数值出错\n原因是:' + str(error))

# 可以元组式捕获异常
# 一个 except 子句可以同时处理多个异常,这些异常将被放在一个括号里成为一个元组。
try:
    s = 1 + '1'
    int("abc")
    f = open('test.txt')
    print(f.read())
    f.close()
except (OSError, TypeError, ValueError) as error:
    print('出错了!\n原因是:' + str(error))

 

4. try - except - finally 语句

  • 概念
    • 不管try子句里面有没有发生异常,finally子句都会执行。
    • 如果一个异常在try子句里被抛出,而又没有任何的except把它截住,那么这个异常会在finally子句执行后被抛出。
  • 代码
    # 如果错误信息没有被捕获那也会执行finally的代码
    try:
        print('1'+2)
        f = open('test.txt')
        print(f.read())
        f.close()
    except OSError:
        print('打开文件出错')
    finally:
        print('我是必须执行的')
    

5. try - except - else 语句

  • 概念
    • 如果在try子句执行时没有发生异常,Python将执行else语句后的语句。
  • 代码
    # 如果没有错误就执行else
    try:
        print(1)
    except OSError:
        print('打开文件出错')
    else:
        print('没有错误很棒棒')
    
    # 如果有错误就不会执行else
    try:
        f = open('test.txt')
        print(f.read())
        f.close()
    except OSError:
        print('打开文件出错')
    else:
        print('没有错误很棒棒')
    
    # 如果使用else和finally,else要在finally之前,否则语法错误
    try:
        f = open('test.txt')
        print(f.read())
        f.close()
    except OSError:
        print('打开文件出错')
    else:
        print('没有错误很棒棒')
    finally:
        print('我是必须执行的')

5. raise语句

  • 概念
    • Python 使用raise语句抛出一个指定的异常。
  • 代码
    try:
        raise NameError('余生大大')
    except NameError as error:
        print(error)

 

练习题

1、猜数字游戏

题目描述:

电脑产生一个零到100之间的随机数字,然后让用户来猜,如果用户猜的数字比这个数字大,提示太大,否则提示太小,当用户正好猜中电脑会提示,"恭喜你猜到了这个数是......"。在用户每次猜测之前程序会输出用户是第几次猜测,如果用户输入的根本不是一个数字,程序会告诉用户"输入无效"。

(尝试使用try catch异常处理结构对输入情况进行处理)

获取随机数采用random模块。

 

代码:

import random
num = 0;
randomNum = random.randint(0,100)
while 1:
    num+=1;
    print("第",num,"次猜")
    try:
        inputStr = input("请输出一个整形数字");
        print(inputStr,type(inputStr))
        if(int(inputStr) > randomNum):
            print("大了")
        elif(int(inputStr) < randomNum):
            print("小了")
        else:
            print("猜对了,厉害")
            break
    except (TypeError,ValueError):
        print("输入的类型不对,请输入整数")

 

好的,我可以为您介绍一下如何用 Python 实现选拔队员和组队建模的问题。 1. 选拔队员 如果您有一群候选队员,您可以使用 Python 完成以下步骤: - 编写一个函数来评估每个候选队员的技能和经验。这可以是一个基于分数的系统,也可以是一个基于等级的系统,根据您的需求来定制。 - 将所有候选队员的数据存储在一个数据结构中,例如列表或字典。 - 使用 Python 的排序函数对候选队员进行排序,根据他们的技能和经验进行排名。 - 根据您的选拔标准,选择前几名的候选队员,组成您的团队。您可以使用 Python 的切片操作来选择列表中的前几个元素。 以下是一个示例代码: ```python candidates = { 'Alice': {'skill': 90, 'experience': 3}, 'Bob': {'skill': 80, 'experience': 4}, 'Charlie': {'skill': 70, 'experience': 5}, } def evaluate_candidate(candidate): # 评估候选队员的技能和经验 return candidate['skill'] * candidate['experience'] sorted_candidates = sorted(candidates.items(), key=lambda x: evaluate_candidate(x[1]), reverse=True) team = sorted_candidates[:2] # 选择前两名的候选队员 ``` 2. 组队建模 如果您已经选拔出了一组队员,您可以使用 Python 进行组队建模: - 确定建模目标。您需要确定您要解决的问题,并选择合适的建模方法。 - 收集数据。您需要收集与问题相关的数据,并将其存储在一个格式化的数据结构中,例如 Pandas 的 DataFrame。 - 数据清洗和转换。您需要对数据进行清洗和转换,以便于后续建模使用。 - 选择合适的模。根据您的建模目标和数据特征,选择适当的模,例如决策树、线性回归或神经网络等。 - 训练模。使用您的数据集来训练模,并调整模参数以达到最佳效果。 - 测试和评估模。使用测试数据集来评估模的性能,并根据需要调整模。 - 部署模。将您的模部署到生产环境中,并使用它来解决实际问题。 以下是一个示例代码: ```python import pandas as pd from sklearn.tree import DecisionTreeClassifier from sklearn.model_selection import train_test_split # 收集数据 data = pd.read_csv('data.csv') # 数据清洗和转换 data = data.dropna() X = data[['feature1', 'feature2']] y = data['label'] # 选择模和训练模 X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2) model = DecisionTreeClassifier() model.fit(X_train, y_train) # 测试和评估模 score = model.score(X_test, y_test) # 部署模 # ... ``` 希望这些代码可以帮助您解决问题!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

余生大大

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值