内容概要

  • 异常捕获(补充)
  • for循环本质
  • 生成器
  • yield 和 return优缺点
  • 笔试题
  • 常用内置函数

内容详细

一、异常捕获补充

try:
print(name)
except NameError as e:
print('接收类型错误')
except Exception:
print('接收所有错误类型')
else:
print('代码出错的时候才会执行这段代码')
finally:
print('无论代码出不出错,都会执行这段自代码') # 主动报错,一般用于监控某些代码运行到一定峰值的时候报警
raise NameError # 插入,判断一个变量名是否为指定类型
name = 'elijah'
assert isinstance(name, str)

二、for循环本质

# in 后面的的可迭代对象调用__iter__方法转为迭代器对象
# 开启循环,打印迭代器对象调用__next__方法取出来的值
# 做异常处理,当值被取完之后会报错,报错处理是break退出循环 l = [11, 33, 44, 55, 66, 77] res = l.__iter__()
while True:
try:
print(res.__next__())
except Exception:
break # for 循环
for i in l:
print(i)

三、索引取值与迭代器对象取值

迭代器取值:
优:
1.不依赖于索引的一种通用取值方式
缺:
1.取值的顺序永远都是固定从左往右,无法重复获取
索引取值:
缺:
1.需要提供有序容器类型才可取值(不是一种通用的方式)
优:
1.可以重复取值

四、生成器对象

'''
生成器是自定义的迭代器,和迭代器一样,都是相当于一个“工厂”,只在需要数据的时候调用__next__方法取出数据,节省内存空间
''' '''列表生成式'''
l = ['elijah', 'jason', 'kevin', 'egon']
res = [f'{i}_DSB' for i in l]
print(res) # ['elijah_DSB', 'jason_DSB', 'kevin_DSB', 'egon_DSB'] '''字典生成式'''
l = ['elijah', 'jason', 'kevin', 'egon']
l1 = [30000, 40000, 50000, 60000] res1 = {j: l1[i] for i, j in enumerate(l)}
print(res1) # {'elijah': 30000, 'jason': 40000, 'kevin': 50000, 'egon': 60000} # 没有元组生成式,加括号的是生成器
l = ['elijah', 'jason', 'kevin', 'egon']
res2 = (i for i in l) while True:
try:
print(res2.__next__())
except Exception:
break
'''yield关键字'''
def genorates():
print('first code')
yield
print('second code')
yield '''
当函数体内有yield关键字,那么在第一次调用函数的时候
并不会执行函数体代码,而是将函数变成了生成器(迭代器)
'''
res = genorates()
print(res.__next__()) '''
函数代码执行碰到yield,只会停止不会立刻结束,直至函数代码运行结束
''' # yield传值
def eat(name):
print('%s 准备干饭!!' % name)
while True:
food = yield
print('%s 正在吃 %s' % (name, food)) res = eat('elijah') # 并不会执行代码 而是转换成生成器
res.__next__()
res.send('肉包子') # 给yield传值
res.send('盖浇饭')

五、笔试题

def run(n, i):
return n + i def test():
for i in range(4):
yield i g = test() for n in [1, 10]: # 别把[1, 10]看成range(1, 10), 这是个只有两个元素的列表
g = (run(n, i) for i in g)
'''
循环两次:
1.n=1, g = (run(n, i) for i in g)
2.n=10,g= (run(n, i) for i in (run(n, i) for i in g))
'''
# 运行两遍,相当于 g = (run(n, i) for i in (run(n, i) for i in g))
# 因为生成器在未调用之前把它当成一个式子 res = list(g)
print(res)

六、yield 和 return

yield
1.可以返回值(支持返回多个并组织成元组)
1.yield可以将函数变成生成器,并且支持外界传值
2.只是让函数'停止',不会结束
return
1.可以返回值(支持多个并组织成元组)
1.运行函数遇到return即停止

七、内置函数

# 1.abs()  取绝对值

abs(123)
abs(-123) # 2.chr() ord()
chr(97) # a => 返回数字对应的字符串
ord('A') # 65 => 返回字符串对应的ASCII表数字 # 3.isinstance(name, str)
判断变量名是否是指定的数据类型 # 4.callable(func)
判断变量名是否是可运行的函数名 # 5.all() any() l = [1, 2, 3, 0] all(l) -> False, 当容器里所有的值都是True时才返回True
any(l) -> True, 只要容器里有一个值是True,就会返回True # 6.bin() oct() hex() 进制数
print(bin(123)) # 转为二进制 0b1111011
print(oct(123)) # 转为十进制 0o173
print(hex(123)) # 转为十六进制 0x7b # 7.bytes() str()
res = '选择方向,有效努力'
res1 = bytes(res, 'utf8') # 把字符串按照指定编码转换成二进制数,第一个传入变量名参数,第二个是字符编码
print(res1)
res2 = str(res1, 'utf8')
print(res2) # 8.complex() 复数
print(complex(123)) # (123 + 0j) # 9.dir() 查看当前对象可以调用的名字
def index():
pass print(dir(index)) # ['__dict__', '__dir__', '__doc__'......] # 10.divmod()
print(divmod(101, 10))
print(divmod(233, 10)) # 小应用:10条数据为一页,有233条数据,要分多少页
def count(nums, num):
c1, c2 = divmod(nums, num)
if c2:
c1 += 1
print('需要分 %s 页' % c1) count(233, 10) # 11.eval() 只能识别简单的语法, exec()可以识别复杂语法,都是将字符串中的数据内容加载,如果识别到可执行的python语法会执行 res = '''
for i in range(5):
print(i)
'''
exec(res) # 打印0,1,2,3,4 res = '''
print('hello, world!')
'''
eval(res) # hello, world! # 12.pow(a, b) 求a的b次方
pow(3, 3) # 27 # 13.round() 五舍六入
print(round(4.8)) # 5
print(round(4.6)) # 5
print(round(4.5)) # 4 # 14.sum() 求总和 l = [11, 22, 33, 44, 55, 66, 77]
print(sum(l))

生成器对象知识仿造range()

# 生成器形式
def my_range(start, stop=None, step=1):
if not stop:
stop = start
start = 0
while start < stop:
yield start
start += 1 res = my_range(10) # 需要注意的是,含有yield关键字函数第一次运行只是转换成生成器对象
print(res.__next__()) # 依次取值
print(res.__next__())
print(res.__next__())
print(res.__next__()) # 易错点 print(my_range(10).__next__())
print(my_range(10).__next__())
print(my_range(10).__next__()) '''
这样子其实是每次都重新把函数转换成一个新的生成器对象,所以每次都只能取到第一个值
'''

python生成器对象&常见内置函数的更多相关文章

  1. 12.Python略有小成(生成器,推导式,内置函数,闭包)

    Python(生成器,推导式,内置函数,闭包) 一.生成器初始 生成器的本质就是迭代器,python社区中认为生成器与迭代器是一种 生成器与迭代器的唯一区别,生成器是我们自己用python代码构建成的 ...

  2. Python函数04/生成器/推导式/内置函数

    Python函数04/生成器/推导式/内置函数 目录 Python函数04/生成器/推导式/内置函数 内容大纲 1.生成器 2.推导式 3.内置函数(一) 4.今日总结 5.今日练习 内容大纲 1.生 ...

  3. python 常见内置函数setattr、getattr、delattr、setitem、getitem、delitem

    常见内置函数 内置函数:在类的内部,特定时机自动触发的函数 示例1:setattr.getattr.delattr class Person: # def __init__(self, name): ...

  4. python 类(object)的内置函数

    python 类(object)的内置函数 # python 类(object)的内置函数 ### 首先 #### 以__双下划线开头的内置函数 __ #### __往往会在某些时候被自动调用,例如之 ...

  5. Python标准库:内置函数hasattr(object, name)

    Python标准库:内置函数hasattr(object, name) 本函数是用来判断对象object的属性(name表示)是否存在.如果属性(name表示)存在,则返回True,否则返回False ...

  6. Jmeter系类(32) - JSR223(2) | Groovy常见内置函数及调用

    常见内置函数及调用 获取相关函数 获取返回数据并转换为String字符串 prev.getResponseDataAsString() 例子 String Responsedata = prev.ge ...

  7. python字符串——"奇葩“的内置函数

      一.前言 python编程语言里的字符串与我们初期所学的c语言内的字符串还是有一定不同的,比如python字符串里的内置函数就比语言的要多得多:字符串内的书写格式也会有一点差异,例:字符串内含有引 ...

  8. 记录我的 python 学习历程-Day12 生成器/推导式/内置函数Ⅰ

    一.生成器 初识生成器 生成器的本质就是迭代器,在python社区中,大多数时候都把迭代器和生成器是做同一个概念. 唯一的不同就是: 迭代器都是Python给你提供的已经写好的工具或者通过数据转化得来 ...

  9. python之迭代器 生成器 枚举 常用内置函数 递归

    迭代器 迭代器对象:有__next__()方法的对象是迭代器对象,迭代器对象依赖__next__()方法进行依次取值 with open('text.txt','rb',) as f: res = f ...

随机推荐

  1. Echart可视化学习(一)

    文档的源代码地址,需要的下载就可以了(访问密码:7567) https://url56.ctfile.com/f/34653256-527823386-04154f 正文: 创建需要的目录结构及文件 ...

  2. 记一次 WinDbg 分析 .NET 某工厂MES系统 内存泄漏分析

    一:背景 1. 讲故事 上个月有位朋友加微信求助,说他的程序跑着跑着就内存爆掉了,寻求如何解决,截图如下: 从聊天内容看,这位朋友压力还是蛮大的,话说这貌似是我分析的第三个 MES 系统了,看样子 . ...

  3. 关于CKCsec安全研究院

    关于CKCsec安全研究院 CKCsec安全研究院所有文档开源于语雀,会源源不断更新. 部分内容 微信公众号 知识星球 使用需知 由于传播.利用此文所提供的信息而造成的任何直接或者间接的后果及损失,均 ...

  4. Flowable实战(八)BPMN2.0 任务

      任务是流程中最重要的组成部分.Flowable提供了多种任务类型,以满足实际需求.   常用任务类型有: 用户任务 Java Service任务 脚本任务 业务规则任务 执行监听器 任务监听器 多 ...

  5. java基础01-03-注释、标识符、数据类型讲解

    java基础01-注释 java中的注释有三种: 单行注释 多行注释 文件注释 public class helloworld { public static void main(String[] a ...

  6. JUC之线程池基础与简单源码分析

    线程池 定义和方法 线程池的工作时控制运行的线程数量,处理过程中将任务放入队列,然后在线程创建后启动这些任务,如果线程数量超过了最大数量,超出数量的线程排队等候,等待其他线程执行完成,再从队列中取出任 ...

  7. DEEP LEARNING WITH PYTORCH: A 60 MINUTE BLITZ | TENSORS

    Tensor是一种特殊的数据结构,非常类似于数组和矩阵.在PyTorch中,我们使用tensor编码模型的输入和输出,以及模型的参数. Tensor类似于Numpy的数组,除了tensor可以在GPU ...

  8. Maven 框架结构知识总结

    1.maven目录结构 目录 内容 ${basedir} 存放pom.xml和所有子目录 ${basedir}/src/main/java 项目Java代码 ${basedir}/src/main/r ...

  9. 【刷题-LeetCode】239. Sliding Window Maximum

    Sliding Window Maximum Given an array nums, there is a sliding window of size k which is moving from ...

  10. 【记录一个问题】一个golang中的BUG,为啥编译的时候无法发现,而单独跑测试用例就发现了

    代码大致如下: func DoSomething(){ log.Printf("a=%s, b=%s, c=%s", a, b) //忘记少写一个参数.但是编译正常通过 } fun ...