Python 推导式、迭代器、生成器、模块和包
一、推导式
(一).列表推导式(集合推导式也同理于此)
利用列表推导式,取出1-20内所有偶数
li = [i for i in range(1, 21) if i % 2 == 0] # 如果只有一个条件,要把if语句写在最后面
第一个i是放入列表的值,后面都是推导的公式
print(li)
第一个 i 相当于下面等价方案中的 append(i)。把 i 换成 "a" ,输出的列表中全是 "a"
等价于
for i in range(1,21):
if i%2==0:
li.append(li)
print(li)
利用列表推导式,取出1-20内所有数。其中奇数用字符"a"代替,偶数则正常输出
li = [i if i % 2 == 0 else "a" for i in range(1, 21)] # 添加多个条件的时候,要写在前面
print(li)
列表推导式练习:将列表 li=['a','b','c','d','e'] 倒序
print([li.pop() for i in range(len(li))])
pop()函数,remove and return the last element
(二).字典推导式
例1:
a = {str(i): i for i in range(5)}
print(a) # {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4}
例2:
a = {"i": i for i in range(5)}
print(a) # {'i': 4}
因为字典的键是唯一的,“例2”中的这个推导式,把键的名字给写死了,每一次推导其实都是在修改原先的值。
例3:
print({i: 'a' for i in range(5)})
{0: 'a', 1: 'a', 2: 'a', 3: 'a', 4: 'a'}
“例3”是把值给写死了。相当于dict.fromkeys([0,1,2,3,4],"a")
(三).元祖的话,是返回一个生成器对象:
print((i for i in range(5)))
<generator object at 0x01760960>
需要用tuple()来查看:
print(tuple(i for i in range(5)))
(0, 1, 2, 3, 4)
二、迭代器
查看一个对象是否可迭代,使用dir(li)方法,结果中出现了 "iter" 就是可迭代。
使用dir(li)查看,要有 "iter" 和 "next" 才算是一个迭代器。
枚举就是个迭代器
g = enumerate([1, 2, 3])
print(dir(g))
dir(g) 后,可以看到有 "iter" 和 "next"
(一).__iter__() 和 next():
(1).__iter__()把一个可迭代的对象变成迭代器。
li = [1, 2, 3]
g = li.__iter__() # 用这个方法变成迭代器
print(g.__next__()) # 实现迭代器(通俗理解:取值)
要赋值给一个变量。不然__next__()每次都是取第一个值
下面这样写,取的永远都是迭代器中的第一个值
print(li.__iter__().__next__())
print(li.__iter__().__next__())
print(li.__iter__().__next__())
这里就理解:!迭代器对象,必须赋值给一个变量接受!
(2).__next__(),实现迭代器,本质就是取出迭代器的下一个元素。注意:元素取完了,如果再 next() 就会报 StopIteration 异常!
li = [1, 2, 3]
g = iter(li)
print(next(g)) # 这里已经把第一个元素取出了
print("---")
for i in g: # 所以这里只会取出后面的2个值
print(i)
三、生成器 generator
在python中,使用了关键字yield的函数被成为生成器。本质上是迭代器,关键字:yield
跟普通函数不同的是,生成器是一个返回迭代器的函数,只能用于迭代操作。
在调用生成器运行的过程中,每次遇到yield时,函数会暂停并保存当前所有的运行信息,返回yield的值。并在下一次执行next()方法时,从当前位置继续运行。:
如下演示一个简单的生成器:
def fun():
i = 1
while i < 5:
print(i)
# yield # 实现生成器的功能。1、暂停,2、返回值。
yield "stop" # 可以这样写,返回一个信息
i += 1
print("**", i)
print(fun()) # 这里返回了一个内存地址
f = fun()
print(next(f))
使用yield演示斐波那契:
def fab(max_num):
n, a, b = 0, 0, 1
while n < max_num:
yield "暂停 打印b:", b
a, b = b, a + b
n += 1
for x in fab(20):
print(x)
四、模块和包
(一).模块:本质上就是py文件。分为:内置模块,第三方模块。
(1).内置模块的使用:
导入所有内容:import modulename;很直观,但很占内存。
指定导入:from modulename import funcationname;明确知道自己要用什么方法。
(2).自定义模块的使用:
与当前py文件是同级路径:直接导入。
不同路径导入的参考:
import sys # 别忘了先导入这个
sys.path # 路径先调出来。返回一个列表,是python的安装目录
sys.path.append(r"") # 小括号内可添加自己py文件的绝对路径,记得取消转义
再 import modulename 就可以了
(3).得在自己写的py文件的最后一行加入:
if name == 'main':
functionname1()
functionname2()
有这段代码。测试是本身就有,还是导入进来的。
一定要对这个py文件本身执行,运行了,才会有结果。
(二).包:很多py文件放在一个文件夹中。
(三).if name == 'main':
就是个if判断,'main'就是个字符串,判断是导入的还是直接执行的。
当import一个py模块(文件)的时候,会把那个py模块(文件)执行一遍。
例1:
我有一个"test1.py"的模块(文件),如下代码:
import test2
print(name) # main
print(test2.__name__) # test2
"""
运行结果:
fengzi111
main
test2
"""
有另一个"test2.py"的文件,如下代码:
print("fengzi111")
if name == 'main':
print("fengzi222")
"test1.py"中,import了"test2",那么"test2.py"就被执行了一遍。所以在"test1.py"的运行结果中,会出现fengzi111,因为 import test2 的时候,"test2.py"被执行了一遍。
为什么打印不出fengzi222?
"test2.py"是被引入进"test1.py"中的。"test2.py"中就有了if判断,判断的结果:它们两个不是同一个name。
看"test1.py"文件中的这条代码 print(test2.__name__),这条代码特意显示了一下"test2.py"是什么名字。返回的结果是 test2,但现在执行的是"test1.py"这个文件呀!"test1"=="test2"吗?显然是False,那就不会有fengzi222了。
Python 推导式、迭代器、生成器、模块和包的更多相关文章
- Python迭代器生成器,模块和包
1.迭代器和生成器 2.模块和包 1.迭代器 迭代器对象要求支持迭代器协议的对象,在Python中,支持迭代器协议就是实现对象的__iter__()和__next__()方法. 其中__it ...
- Python_迭代器、生成器、列表推导式,生成器表达式
1.迭代器 (1)可迭代对象 s1 = ' for i in s1: print(i) 可迭代对象 示例结果: D:\Python36\python.exe "E:/Python/课堂视频/ ...
- python之三元表达式、列表推导式、生成器表达式、递归、匿名函数、内置函数
一 三元表达式.列表推导式.生成器表达式 一 三元表达式 name=input('姓名>>: ') res='SB' if name == 'alex' else 'NB' print(r ...
- python基础知识15---三元表达式、列表推导式、生成器表达式、递归、匿名函数、内置函数
阅读目录 一 三元表达式.列表推导式.生成器表达式 二 递归与二分法 三 匿名函数 四 内置函数 五 阶段性练习 一. 三元表达式.列表推导式.生成器表达式 1 三元表达式 name=input('姓 ...
- Python之推导式、生成器表达式
l = [i for i in range(10)] print(l) l1 = ['选项%s'%i for i in range(10)] print(l1) 1.把列表解析的[]换成()得到的就是 ...
- python全栈开发 生成器 :生成器函数,推导式及生成器表达式
python 全栈开发 1.生成器函数 2.推导式 3.生成器表达式 一.生成器函数 1.生成器: 生成器的本质就是迭代器 (1)生成器的特点和迭代器一样.取值方式和迭代器一样(__next__(), ...
- Python进阶(四)----生成器、列表推导式、生成器推导式、匿名函数和内置函数
Python进阶(四)----生成器.列表推导式.生成器推导式.匿名函数和内置函数 一丶生成器 本质: 就是迭代器 生成器产生的方式: 1.生成器函数
- python基础17_列表推导式 vs 生成器表达式
[ ] 列表推导式,是用简单的语法来生成列表, ( ) 生成器表达式,是用简单的语法创建个生成器. 外观上仅括号不一样. 虽然写起来方便,但是读起来稍显费力,另外,不易调试. # 列表推导式 prin ...
- python 三元表达式、列表推导式、生成器表达式、递归、匿名函数、内置函数
http://www.cnblogs.com/linhaifeng/articles/7580830.html 三元表达式.列表推导式.生成器表达式.递归.匿名函数.内置函数
- python 三元表达式、列表推导式、生成器表达式
一 三元表达式.列表推导式.生成器表达式 一 三元表达式 name=input('姓名>>: ') res='mm' if name == 'hahah' else 'NB' print( ...
随机推荐
- 阿里云域名绑定IP
前提条件:拥有一个阿里云域名,拥有一台自己的服务器,并且知道ip,我的是nginx 1.登陆阿里云https://www.aliyun.com/ 2.选择域名与网站,会看到自己拥有的域名,比如我的是m ...
- 面试题:Add Two Numbers(模拟单链表)
题干: You are given two non-empty linked lists representing two non-negative integers. The digits are ...
- Filter及FilterChain的详解
一.Filter的介绍及使用 什么是过滤器? 与Servlet相似,过滤器是一些web应用程序组件,可以绑定到一个web应用程序中.但是与其他web应用程序组件不同的是,过滤器是"链&quo ...
- SparkMLlib基础内容
SparkMLlib基础内容 (一),多种数据类型 1.1 本地向量集 def testVetor: Unit ={ val vd:Vector=Vectors.dense(2,3,6) printl ...
- 针对ecshop错误404页面的优化
在ecshop系统当中,比如你随意将商品详细页面的地址中的ID修改为一个不存在的商品ID,ecshop会自动跳转到首页.ecshop在这方面做得非常的差,甚至导致了很多的站不被搜索引擎收录.最模板提供 ...
- Solidworks草图或者特征无法删除怎么办
单击重新建模之后即可删除.
- [CSS3]移动Web开发系列之CSS3增强型选择器
css3是移动Web开发的主要技术之中的一个.当前.CSS3技术最适合在移动Web开发中使用的特性有增强的选择器.阴影.强大的背景设置 .圆角边框 接下来我们主要解说增强型的选择器.主要分两种,属性选 ...
- 单例模式 - GCD 、兼容ARC和MRC
单例模式 - GCD .兼容ARC和MRC 单例模式的作用: 1,能够保证在程序执行过程.一个类仅仅有一个实例,并且该实例易于供外界訪问 2,从而方便地控制了实例个数,并节约系统资源 单例模式的使用场 ...
- Makefile.am, Makefile.in 与 Makefile的关系(转)
文章出处:http://blog.mcuol.com/User/wangguangdong/Article/17384_1.htm Makefile.am, Makefile.in, Makefile ...
- 【LoadRunner】安装LoadRunner
LoadRunner安装 下载好LoadRunner安装包,点击运行 在点击安装后,会提示需要安装一下程序,直接点击[确定]安装即可. 上述程序安装完毕后,会自动弹出下面的窗口,点击[下一步] 选择[ ...