首页 > 其他分享 >异常和生成器

异常和生成器

时间:2022-10-17 16:34:21浏览次数:53  
标签:__ res 代码 生成器 yield print 异常

目录

异常常见类型

SyntaError
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 isinstance(name,str)
print('哈哈,肯定是字符串')
name.strip()

2. 主动抛异常
name = 'jason'
if name == 'jason':
   raise Exception('老子不干了')
else:
   print('正常走')

异常处理实战应用

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

课堂练习:
使用while循环+异常处理+迭代器对象 完成for循环迭代取值的功能
l1 = [11, 22, 33, 44, 55, 66, 77, 88, 99]
# 1. 先将列表调用__iter__转变成迭代器对象
iter_l1 = l1.__iter__()
# 2. while循环让迭代器对象反复执行__next__
while True:
   try:
      print(iter_l1.__next__())
   except Exception as e:
      break

生成器对象

1.本质
   还是内置有__iter__和__next__的迭代器对象
2.区别
  迭代器对象是解释器自动提供的
      数据类型\文件对象>>>:迭代器对象
  生成器对象是程序员编写出来的
      代码、关键字>>>:迭代器对象(生成器)
3.创建生成器的基本语法
  函数体代码中填写yield关键字

def my_iter():
   print('哈哈')
   yield
"""
1.函数体代码中如果有yield关键字
  那么函数名加括号并不会执行函数体代码
  会生成一个生成器对象(迭代器对象)
"""

res = my_iter()
'''3.使用加括号之后的结果调用__next__才会执行函数体代码'''

res.__next__()  # 哈哈
'''每次执行完__next__代码都会停在yield位置 下次基于该位置继续往下找第二个yield'''

def my_iter():
   print('哈哈哈 椰子汁很好喝')
   yield 111, 222, 333
   print('呵呵呵 从小喝到大')
   yield 111, 222, 333
   print('嘿嘿嘿 特种兵牌还可以')
   yield 111, 222, 333
   print('呵呵呵 千万别整多了  倒沫子')
   yield 111, 222, 333
res = my_iter()
r1 = res.__next__()
print(r1)  # 哈哈哈 椰子汁很好喝  (111, 222, 333)

r2 = res.__next__()
print(r2)  # 呵呵呵 从小喝到大 (111, 222, 333)

r3 = res.__next__()
print(r3)  # 嘿嘿嘿 特种兵牌还可以 (111, 222, 333)

r4 = res.__next__()
print(r4)  # 呵呵呵 千万别整多了  倒沫子 (111, 222, 333)
课堂练习
# 自定义生成器对标range功能(一个参数 两个参数 三个参数 迭代器对象)
# for i in range(1, 10):
#    print(i)

# 1.先写两个参数的
# 2.在写一个参数的
# 3.最后写三个参数

def my_range(start_num,end_num=None, step=1):
   # 判断end_num是否有值 没有值说明用户只给了一个值 起始数字应该是0 终止位置应该是传的值
   if not end_num:
      end_num = start_num
      start_num = 0
   while start_num < end_num:
      yield start_num
      start_num += step
res = my_range(1,10).__iter__()
while True:
   try:
      i  = res.__next__()
      print(i)
   except StopIteration:
      break

for i in my_range(11):
   print(i)
for i in my_range(2,11):
   print(i)
for i in my_range(5):
   print(i)

yield冷门用法

def eat(name,food=None):
   print(f'{name}准备用餐')
   while True:
      food = yield
      print(f'{name}正在吃{food}')

res = eat('jason')
res.__next__()
res.send('汉堡')  # 1.将括号内的数据传给yield前面的变量名 2.再自动调用__next__
res.send('包子')
res.send('面条')

生成器表达式

# 说白了就是生成器的简化写法
# l1 = [i ** 2 for i in range(100)]
# print(l1)
l1 = (i**2 for i in range(10))  # 生成器对象
print(l1)  # <generator object <genexpr> at 0x0000023A08233C50>
for i in l1:
   print(i)  # 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]
'''不用深入研究 大致知道起始数即可'''

标签:__,res,代码,生成器,yield,print,异常
From: https://www.cnblogs.com/winter-yu1989/p/16799660.html

相关文章

  • 异常捕获
    异常捕获  1.异常通常被称为bug  2.异常结构有三部分   报错定位报错类型:报错详细信息  3.异常可以出现逻辑错误,不能可以出现语法错误  ......
  • python基础之异常处理、生成器对象、生成器表达式
    A-Z65-90a-z97-122迭代取值=for循环取值(每次取值都依赖于上一次取值)python基础之异常处理、生成器对象、生成器表达式目录一、异常处理语法结构1.异常的常见类型2......
  • 【ES6】函数的参数、Symbol数据类型、迭代器与生成器
    ......
  • io流-异常处理
    在JDK1.7之前使用trycatchfinally处理流中的异常格式:try{可能会产生异常的代码}catch(异常类变量变量名){异常的处理逻辑}finally{一定会指定的代码资源释......
  • echarts 在IE11上异常不执行代码的问题
    echarts控件在谷歌浏览器一切正常,但是IE11(windows10上的IE)就不行了,调试发现页面直接就整个异常了,在最开始写了个alert(111)都不执行,看样子应该是哪里有语法错误,导致解析的......
  • NFS共享磁盘异常
    NFS共享磁盘异常故障描述数据库所挂载的nfs存储网络链路出现中断,所有挂载NFS存储节点所对应的服务均出现异常。故障原因根据哈希算法特性,若业务流量五元组一致(源地址、......
  • 自定义异常和练习自定义异常
    自定义异常java中不同的异常类,分别表示着某一种具体的异常情况那么在开发中总是有些异常情况是SUN没有定义好的此时我们根据自己业务的异常情况来定义异常类例如年龄......
  • 异常的分类
    我们平常说的异常是指Exception因为这类异常一旦出现我们就是对代码进行更正修复程序异常(Exception)的分类:根据在编译时期还是运行时期去检查异常编译时期异常:checke......
  • 异常的处理-抛出异常throw
    抛出异常throw在编写程序时我们必须要考虑程序出现的问题的情况比如在定义方法时方法需要接受在java中提供了一个thow关键字它用来抛出一个指定的异常对象 1.创......
  • 基于雪花算法的增强版ID生成器
    sequence基于雪花算法的增强版ID生成器解决了时间回拨的问题无需手动指定workId,微服务环境自适应可配置化快速开始依赖引入<dependency><groupId>io.githu......