首页 > 其他分享 >异常处理语法结构、yield生成器及其表达式

异常处理语法结构、yield生成器及其表达式

时间:2022-10-17 17:00:25浏览次数:52  
标签:res 代码 生成器 yield 语法结构 print next

今日内容回顾

目录

  • 异常处理语法结构
  • 异常处理实战应用
  • 生成器对象
  • 自定义range功能
  • yield冷门用法
  • yield与return对比
  • 生成器表达式
  • 笔试题

异常处理语法结构

# 常见的异常类型
SynataxError  语法错误
NameError  名字错误
IndexError  索引错误
KeyError  键取值错误
IndentationError  缩进错误
1.基本语法结构
	try:
        待监测的代码(可能会出错的代码)
    except 错误类型:
        针对上述错误类型制定的方案
2.查看错误类型
	try:
        待监测的代码(可能会出错的代码)
    except 错误类型 as e: # e就是系统提示的错误信息
        针对上述错误类型制定的方案
3.针对不同的错误类型制定不同的解决方案
	try:
        待监测的代码(可能会出错的代码)
    except 错误类型1 as e: # e就是系统提示的错误信息
        针对上述错误类型1制定的方案
    except 错误类型2 as e: # e就是系统提示的错误信息
        针对上述错误类型2制定的方案
    except 错误类型3 as e: # e就是系统提示的错误信息
        针对上述错误类型3制定的方案
    ...
    
4.万能异常 Exception/BaseException
	try:
        待监测的代码(可能会报错的代码)
    except Exception as e:  #e就是系统提示的错误信息
        针对各种常见的错误类型全部统一处理
5.结合else使用
	try:
        待监测的代码(可能会出错的代码)
    except Exception as e:  #e就是系统提示的错误信息
        正对各种常见的错误类型全部统一处理
    else:
        try的子代码正常运行结束没有任何的报错后 再执行else子代码
6.结合finally使用
	try:
        待监测的代码(可能会出错的代码)
    except Exception as e:  # e就是系统提示的错误信息
        针对各种常见的错误类型全部统一处理
    else:
        try的子代码正常结束没有任何的报错后 再执行else子代码
    finally:
        无论try的子代码是否报错 最后都要执行finally的子代码

# 异常处理补充
1.断言
name = 'jason'
assert isinstence(name, int) # 提前去判断它是不是整型 是的话打印下面一句 不是则报错断言错误错误
print('好好学习')
2.主动报异常
name = 'jason'
if name == 'jason':  # 当name是jason的时候就主动报错:raise Exception('啊哈') Exception: 啊哈
    raise Exception('啊哈')
else:
    print('哦豁')

异常处理实战应用

1.异常处理能尽量少用就少用
2.被try监测的代码能尽量少用就少用
3.当代码中可能会出现一些无法控制的情况才应该考虑使用
如:使用手机访问网络软件 断网
	编写网络爬虫程序请求数据 断网
练习:
使用while循环+异常处理+迭代器对象 完成for循环迭代取值得功能
l1 = [11, 33, 44, 55, 33, 66, 77, 33, 99]
# 1.首先将列表调用_iter_转变成迭代器对象
res = l1.__iter__()
# 2.while循环让迭代器对象反复执行_next_
while True:
    try:
        print(res.__next__())
    except Exception as e:
        break

生成器对象

1.本质
	还是内置有_iter_和_next_的迭代对象
2.区别
	迭代对象是解释器自动提供的
    	数据类型\文件对象>>>:迭代器对象
    生成器对象是程序员编写出来的
    	代码、关键字>>>: 迭代器对象(生成器)
3.创建生成器的基本语法
	函数体代码中填写yield关键字
    def my_iter():
        print('我爱学习')
        yield
        '''
        函数体代码中如果有yield关键字
        那么函数名加括号不会执行函数体代码
        会生成一个生成器对象(迭代器对象)
        '''
        res = my_iter()
        '''
        使用加括号之后的结果调用_next_才会执行函数体代码
        '''
        res._next()
        '''
        每次执行完_next_代码都会停在yield位置 下次基于该位置继续往下找第二个yie
        '''
        
def my_iter():
    print('哈哈')
    yield 11, 22, 33
    print('呵呵')
    yield 11, 22, 33
    print('嘿嘿')
   yield 11, 22, 33
res = my_iter_()
r1 = res._next_()
print(r1)  # 哈哈 (11 22 33)
r2 = res._next_()
print(r2)  # 呵呵 (11 22 33)
r3 = res._next_()
print(r3)  # 嘿嘿 (11 22 33)

自定义range功能

自定义生成器实现跟range方法一样的功能(一个参数 两个参数 三个参数)
for i in range(1, 10):
    print(i)
    
def my_range(first, second=None, third=1):
# 判断second是否有值 没有值说明用户只给了一个值 起始数字应该是0 终止位置应该是传的值
    if not second:
        second = first
        first = 0
    while first < second:
        yield first
        first += third

for i in my_range(9):
    print(i)
for i in my_range(1, 10):
    print(i)
for i in my_range(1, 20, 2):
    print(i)

yield冷门用法

def eat(name):
    print('%s 准备干饭!!!'%name)
    while True:
        food = yield
        print('%s 正在吃 %s' % (name, food))
res = eat('jason')  # 并不会执行代码 而是转换成生成器
res.__next__()
res.send('面条')  # 通过send传值给yield赋值号左边的的变量名
res.send('盖浇饭')

yield与return对比

yield
	1.可以有返回值(支持多个并且组织成元组)
    2.函数体代码遇到yield不会结束而是'停住'
    3.yield可以将函数变成生成器 并且还支持外界传值
return
	1.可以返回值
    2.函数体代码遇到return直接结束

生成器表达式

# 就是生成器的简化写法
l1 = [i ** 2 for i in range(10)]
print(l1)  # [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

l1 = (i ** 2 for i in range(10)) # 就是个生成器对象
print(l1)  # <generator object <genexpr> at 0x0000026509542DB0>
print(l1._next_()) # 0
print(l1._next_())  # 1
print(l1._next_())  # 4
for i in l1:
    print(i)  
print(list(l1))  # [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

笔试题

"""
面试题(有难度)
	大致知道流程即可
"""
def add(n, i):  # 普通函数 返回两个数的和  求和函数
    return n + i
def test():  # 生成器
    for i in range(4):
        yield i
g = test()  # 激活变成生成器
for n in [1, 10]:
    g = (add(n, 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)
print(res)

#A. res=[10,11,12,13]
#B. res=[11,12,13,14]
#C. res=[20,21,22,23]
#D. res=[21,22,23,24]
答案:C

标签:res,代码,生成器,yield,语法结构,print,next
From: https://www.cnblogs.com/xiao-fu-zi/p/16799797.html

相关文章

  • day16 异常处理生成器
    day16异常处理生成器今日内容概要异常处理异常处理实战应用生成器对象生成器对象实现range方法生成器表达式今日内容详细一、异常处理1.异常常见类型Synt......
  • python进阶之路15 之异常处理、生成器相关
    异常捕获处理1.异常异常就是代码运行报错行业术语叫bug代码运行中一旦遇到异常会直接结束整个程序的运行我们在编写代码的过程中要尽可能避免2.异常分类......
  • python基础之生成器
    异常处理语法结构异常处理实战应用生成器对象生成器对象实现range方法生成器表达式生成器笔试题模块简介今日内容详细异常常见类型SyntanxError语法错误Nam......
  • 进入python的世界_day16_python基础——异常捕获的处理、生成器对象、生成器表达式
    一、异常捕获1.错误类型语法错误>>>syntaxerror名字错误>>>namerror索引错误>>>Indexerror缩进错误>>>indentationerror等等......2.异常处理语法结构1.语法结......
  • 异常、生成器、自定义range
    目录今日内容概要今日内容详细异常常见类型异常处理语法结构异常处理补充异常处理实战应用生成器对象课堂练习yield冷门用法生成器表达式今日内容概要异常处理语法结构......
  • 异常和生成器
    目录异常常见类型异常处理语法结构异常处理补充异常处理实战应用生成器对象yield冷门用法生成器表达式异常常见类型SyntaErrorNameErrorIndexErrorKeyErrorIndentati......
  • python基础之异常处理、生成器对象、生成器表达式
    A-Z65-90a-z97-122迭代取值=for循环取值(每次取值都依赖于上一次取值)python基础之异常处理、生成器对象、生成器表达式目录一、异常处理语法结构1.异常的常见类型2......
  • 【ES6】函数的参数、Symbol数据类型、迭代器与生成器
    ......
  • 基于雪花算法的增强版ID生成器
    sequence基于雪花算法的增强版ID生成器解决了时间回拨的问题无需手动指定workId,微服务环境自适应可配置化快速开始依赖引入<dependency><groupId>io.githu......
  • springboot MP代码生成器
    1、需要的依赖和版本号(我这个是项目完成后的全部依赖,只参照需要的依赖即可)<?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0......