迭代器与生成器:
迭代是Python最强大的功能之一,是访问集合元素的一种方式。
迭代器是一个可以记住遍历的位置的对象。
迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。迭代器只能往前不会后退。
迭代器有两个基本的方法:iter() 和 next()。
字符串,列表或元组对象都可用于创建迭代器
生成器第一种方式:需要将中括号换成小括号
在 Python 中,使用了 yield 的函数被称为生成器(generator)
跟普通函数不同的是,生成器是一个返回迭代器的函数,只能用于迭代操作,更简单点理解生成器就是一个迭代器
在调用生成器运行的过程中,每次遇到 yield 时函数会暂停并保存当前所有的运行信息,返回 yield 的值, 并在下一次执行 next() 方法时从当前位置继续运行
调用一个生成器函数,返回的是一个迭代器对象
一个函数 f,f 返回一个 list,这个 list 是动态计算出来的(不管是数学上的计算还是逻辑上的读取格式化),并且这个 list 会很大(无论是固定很大还是随着输入参数的增大而增大),这个时候,我们希望每次调用这个函数并使用迭代器进行循环的时候一个一个的得到每个 list 元素而不是直接得到一个完整的 list 来节省内存,这个时候 yield 就很有用
打个比方的话,yield有点像断点。 加了yield的函数,每次执行到有yield的时候,会返回yield后面的值 并且函数会暂停,直到下次调用或迭代终止
yield后面可以加多个数值(可以是任意类型),但返回的值是元组类型的
logging:
Logging 函数允许用户对应用程序进行日志记录,并把日志消息发送到电子邮件、系统日志或其他的机器
例:
test=(x for x in range(10)) print(test.__next__()) print(test.__next__()) print(test.__next__())
实现裴波那切序列
def feibonaqie(): a=b=1 print(a) print(b) for i in range(7): yield (a+b) a,b=b,a+b f=feibonaqie() print(f.__next__()) print(f.__next__()) print(f.__next__()) print(f.__next__()) print(f)推导:
numbers1=[x for x in range(100) if x % 3 ==0]
print(numbers1)
列表推导式:
name=['bob','tom','alcie','jerry','wendy','smith']
print(name.upper() for name in name if len(name)>3)
字典式推导、交换values和key的至、值:
mcase={'a':10,'b':22}
mcase_frequency={v:k for k,v in mcase.items()}
print(mcase_frequency)
集合、推导、set集合中不能有重复的:
squared1={x**2 for x in[1,1,2]}
print(squared1)