首页 > 其他分享 >异常处理、生成式对象

异常处理、生成式对象

时间:2022-10-17 20:25:31浏览次数:55  
标签:name 对象 生成式 生成器 except yield num print 异常

1.异常常见类型

SyntaxError:语法错误
NameError:名字错误,一般由于变量名未定义造成
IndexError:索引错误,列表的索引值超过了范围
KeyError:字典键错误,字典的键找不到
IndentationError:缩进错误

2.异常处理语法结构

1.基本语法结构:
    try:
        待监测的代码(可能会出错的代码)
    except 错误类型:
        针对上述错误类型指定的方案
        
try:
    print(name)
except NameError:
    print('变量名没有定义就使用了')  # 变量名没有定义就使用了
"""
如果except后面的错误类型正确,那么就不会报错,而是直接执行except的子代码,错误类型不对还是会报错
"""    
        
2.查看错误信息:
    try:
        待监测的代码(可能会出错的代码)
    except 错误类型 as e:
        针对上述错误类型指定的方案
try:
    print(name)
except NameError as e:
    print('变量名没有定义就使用了')
    print(e)  # 变量名没有定义就使用了 name 'name' is not defined
"""
加一个参数e可以查看具体错误,也可以加上其他代码
"""

3.针队不同的错误类型制定不同的解决方案
	 try:
        待监测的代码(可能会出错的代码)
    except 错误类型1 as e:
        针对上述错误类型指定的方案
    except 错误类型2 as e:
        针对上述错误类型指定的方案
    except 错误类型3 as e:
        针对上述错误类型指定的方案
        
try:
    print(name)
    l1 = [1, 2, 3, 4]
    l1[5]
except IndexError as e:
    print(e)
except NameError as e:
    print(e)
except KeyError as e:
    print(e)  # name 'name' is not defined
"""
如果不确定是哪种错误类型,可以采用上面的格式。但是该形式找到地一个错误类型之后就会停止运行,也就是说运行一次只能找到一处错误
"""

4.万能异常
try:
    待监测代码(可能会出现的代码)
except Exception as e:
    针队各种常见的错误类型全部统一处理

try:
    print(name)
    l1 = [1, 2, 3, 4]
    l1[5]
except Exception as e:
    print(e)  # name 'name' is not defined
"""
一次只能检测一处错误
"""

5.结合else使用:被监测代码没有错误时执行else子代码
try:
    待监测的代码(可能会出现错误的代码)
except Exception as e:
    针队各种常见的错误类型全部统一处理
else:
    try的子代码正常运行结束没有任何的报错后 再执行else子代

try:
    # print(name)
    l1 = [1, 2, 3, 4]
    # l1[5]
except Exception as e:
    print(e)
else:
    print('没有其他错误了')  # 没有其他错误了
    
6.结合finally使用:
    try:
        待监测的代码(可能会出现错误的代码)
    except Exception as e:
        针队各种常见的错误类型全部统一处理
    else:
        try的子代码正常运行结束没有任何的报错后 再执行else子代
	 finally:
        无论try子代码是否报错,最后都要执行finally子代码 
try:
    print(name)
except Exception as e:
    print(e)
else:
    print('没有错误了')
finally:
    print('嘿嘿嘿')  # name 'name' is not defined 嘿嘿嘿

try:
    name = 'jason'
    print(name)
except Exception as e:
    print(e)
else:
    print('没有错误了')
finally:
    print('嘿嘿嘿')  # jason 没有错误了 嘿嘿嘿

3.异常处理补充

1.断言:关键字assert,后面的代码如果是对的name会执行下面的代码,是错的直接会报错
info = 'jerry'
assert isinstance(info, str)
print('看我是否会执行')  # 看我是否会执行

info = 'jerry'
assert isinstance(info, int)
print('看我是否会执行')  # 报错	

2.主动抛异常:
name = 'max'
if name == 'max':
    raise Exception('如果是max则执行我')
else:
    print('name不是max才执行我')  # 执行结果:报错
    
name = 'jason'
if name == 'max':
    raise Exception('如果是max则执行我')
else:
    print('name不是max才执行我')  # name不是max才执行我

4.异常处理实战应用

1.异常处理能尽量少用就少用
2.被try监测的代码能尽量少就尽量少
3.当代码中可能会出现一些无法控制的情况报错才应该考虑使用
	eg: 使用手机访问网络软件 断网
      编写网络爬虫程序请求数据 断网

练习:使用while循环+异常处理+迭代器对象 完成for循环迭代取值的功能
l1 = [11, 22, 33, 44, 55, 66, 77, 88, 99]
new_l1 = l1.__iter__()
while True:
    try:
        print(new_l1.__next__())
    except Exception as e:
        break

5.生成器对象

1.本质:
    还是内只有__iter__和__next__的迭代器对象
    
2.区别:
    迭代器对象是解释器自动提供的,由数据类型,文件对象转变为迭代器对象。
    生成器对象是程序员编写出来的
    
3.创建生成器的基本语法:函数团体代码中填写yield关键字
"""
1.函数体代码中如果有yield关键字,那么函数名加括号不会执行函数体代码,而是会生成一个生成器对象(迭代器对象)
"""
def my_iter():
    print('生成器就是迭代器的一种')
    yield 
my_iter()
"""
2.把加括号的结果赋值给一个变量名,变量名调用__next__才会执行函数体代码
"""
def my_iter():
    print('生成器就是迭代器的一种')
    yield
my_iter()
res = my_iter()
res.__next__()
"""
3.多加一个res.__next___()会报错,因为执行一次代码会停在yield后面(类似鼠标的移动),下次基于该位置再继续往下找第二个yield
"""
def my_iter():
    print('生成器就是迭代器的一种')
    yield
    print('生成器就是迭代器的一种111')
    yield
    print('生成器就是迭代器的一种222')
    yield
my_iter()
res = my_iter()
res.__next__()
res.__next__()
res.__next__()  # 生成器就是迭代器的一种 生成器就是迭代器的一种111 生成器就是迭代器的一种222
"""
4.yield类似return,可以有返回值
"""
def my_iter():
    print('生成器就是迭代器的一种')
    yield 0
    print('生成器就是迭代器的一种111')
    yield 111
    print('生成器就是迭代器的一种222')
    yield 222
my_iter()
res = my_iter()
res1 = res.__next__()
print(res1)
res2 = res.__next__()
print(res2)
res3 = res.__next__()  
print(res3)  # 生成器就是迭代器的一种 0 生成器就是迭代器的一种111 111 生成器就是迭代器的一种222 222

6.自定义生成器range()功能

1.两个参数:
def index(start_num, end_num):
    while start_num < end_num:
        yield start_num
        start_num += 1

for i in index(1, 10):
    print(i)
"""
深层原理:
res = index(1, 10).__iter__()
while True:
    try:
        print(res.__next__())
    except Exception:
        break
"""

        
2.一个参数
"""
for i in range(10)代表10是end_num,所以要首先把10传给第二个参数,再把第一个参数变成0
"""
def my_range(start_num, end_num=None):
    if not end_num:
        end_num = start_num
        start_num = 0
    while start_num < end_num:
        yield start_num
        start_num += 1

for i in my_range(10):
    print(i)
    
3.三个参数
def my_len(start_num, end_num=None, step=1):
    if not end_num:
        end_num = start_num
        start_num = 0
    while start_num < end_num:
        yield start_num
        start_num += step


for i in my_len(1, 10, 2):
    print(i)

7.yield冷门用法

如果yield后面有值,函数体代码会执行到yield行并且返回yield后面的值,如果yield前面有变量名和赋值符号,通过send给此变量名传值
def eat(name, food=None):
    print(f'{name}准备用餐')
    while True:
        food = yield
        print(f'{name}正在吃{food}')

res = eat('jason')  # 变成一个生成器
res.__next__()  # 执行函数体代码
res.send('汉堡')
res.send('包子')

8.生成器表达式

列表生成式:
l1 = [i*3 for i in range(1, 10)]
print(l1)  # [3, 6, 9, 12, 15, 18, 21, 24, 27]

元组生成器:组成一个新元组时直接打印变量名是一个内存地址,用for循环才能得到元组中的值
t1 = (i*3 for i in range(1, 10))
print(t1)  # <generator object <genexpr> at 0x00000284A176F190>
for i in t1:
    print(i)
    
"""
面试题:
"""
def add(n, i):  # 1.普通函数 返回两个数的和  求和函数
    return n + i
def test():  # 2.有yield关键字,定义生成器
    for i in range(4):
        yield i
g = test()  # 3.激活生成器
for n in [1, 10]:  # 4.第一次n=1  5.第二次n=10
    g = (add(n, i) for i in g)  # 5.第一次g = (add(1, i) for i in g)
    #  6.g = (add(10, i) for i in (add(10, i) for i in g))
    """
    第一次for循环
        g = (add(n, i) for i in g)
    第二次for循环
        g = (add(10, i) for i in (add(10, i) for i in g))
    """
res = list(g)  # 7.list(g)相当于for循环
print(res)

标签:name,对象,生成式,生成器,except,yield,num,print,异常
From: https://www.cnblogs.com/zkz0206/p/16800481.html

相关文章

  • [2022.10.17]面向对象之类与对象
    面向对象编程的本质就是:以类的方式组织代码,以对象的组织(封装)技术方法有两种调用方式1.通过创建主函数的对象来调用方法2.通过把“static”修饰符把方法可以直接调用函......
  • win10启动ubuntu报错 参考的对象类型不支持尝试的操作
    问题:在Windows10系统下启动Ubuntu20.04连接WSL2,显示参考的对象类型不支持尝试解决方案:1.临时有效通过管理员身份打开WindowsPowerShell打开之后输入以下命令重置Wins......
  • 异常处理及生成器
    异常处理及生成器异常处理1.异常 异常就是代码运行报错,行业俗称叫bug 代码运行中一旦遇到异常会直接结束整个程序的运行,我们在编写代码的过程中要尽可能的避免2.异常......
  • 异常处理(补充)及生成器基础知识
    昨日内容回顾重要内置函数map()映射 zip()拉链 filter()过滤 sorted()排序常见内置函数abs() round() bytes() int() bin() oct() hex() chr() ord() eval() exec(......
  • 分别使用BP/RBF/GRNN神经网络识别航迹异常matlab仿真
    一、理论基础1.1基于BP神经网络的识别1.2基于RBF神经网络的识别1.3基于GRNN神经网络的识别二、核心程序三、仿真测试结果作者ID:fpga和matlabCSDN主页:https://blog.c......
  • 实验二 类与对象
    实验任务一#include<iostream>#include<complex>intmain(){usingnamespacestd;complex<double>c1{3,4},c2{4.5};//支持两个参数//使用时,在语法层面......
  • 异常处理 生成器
    今日内容异常常见类型NameErrorIndentationErrorSyntaxErrorKeyErrorSyntaxError异常处理语法结构1.基本语法结构try:待检测的代码(可能会出现错误的代码......
  • day16异常以及生成器
    目录今日内容详细异常常见类型异常处理语法结构异常处理补充异常处理实战应用生成器对象课堂练习yield冷门用法生成器表达式今日内容详细异常常见类型AttributeError......
  • 异常捕捉/生成器
    异常常见类型SyntaxError-语法错误NameError-变量名类型错误IndexError-索引错误KeyError-字典键错误IndentationError-缩进错误#注意我们最不允许犯的......
  • 异常和生成式
    异常常见类型AssertionError 断言语句失败(assert后的条件为假)AttributeError 访问的对象属性不存在lmportError 无法导入模块或者对象,主要是路径有误或名称错误ln......