1.列表推导式
直接生成列表,那么当列表中的元素特别多的时候,内存的占有就特别的多,如果是循环成千上万,这样就特别占内存。
2.列表生成器1
将列表推导式转换为列表生成器——将[]使用()来代替
列表生成器2
如果推算的算法比较复杂,用类似列表生成式的 for 循
环无法实现的时候,还可以用函数来实现。
例如:
斐波那契数列
上面的函数和 generator 仅一步之遥。要把 fib 函数变成
generator,只需要把 print(second)改为 yield second 就可以了:
yield关键字的使用:
yield关键字在函数中出现,和return类似,用来返回结果
迭代器
迭代是访问集合元素的一种方式。迭代器是一个可以记住遍历的位置的对
象。迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结
束。迭代器只能往前不会后退。
1.可迭代对象
以直接作用于 for 循环的数据类型有以下几种:
一类是集合数据类型,如 list 、 tuple 、 dict 、 set 、 str 等;
一类是 generator ,包括生成器和带 yield 的 generator function。
这些可以直接作用于 for 循环的对象统称为可迭代对象: Iterable 。
判断是否可以迭代
可以使用 isinstance() 判断一个对象是否是 Iterable 对象:
也可以判断是否有功能:
2.迭代器
可以被 next()函数调用并不断返回下一个值的对象称为迭代器:Iterator。
可以使用 isinstance() 判断一个对象是否是 Iterator 对象:
iter()函数
生成器都是 Iterator 对象,但 list 、 dict 、 str 虽然是 Iterable ,却不是
Iterator 。
把 list 、 dict 、 str 等 Iterable 变成 Iterator 可以使用 iter() 函数:
• 凡是可作用于 for 循环的对象都是 Iterable 类型;
• 凡是可作用于 next() 函数的对象都是 Iterator 类型
• 集合数据类型如 list 、 dict 、 str 等是 Iterable 但不是 Iterator ,不过可以通过
iter() 函数获得一个 Iterator 对象。
• 目的是在使用迭代器的时候,减少内存的占用。