本文实例讲述了Python字典生成式、集合生成式、生成器用法。分享给大家供大家参考,具体如下:
字典生成式:
- 跟列表生成式一样,字典生成式用来快速生成字典,不同的是,字典需要两个值
1
2
3
4
|
#d = {key: value for (key, value) in iterable} d1 = { 'x' : 1 , 'y' : 2 , 'z' : 3 } d2 = {k: v for (k, v) in d1.items()} print (d2) |
集合生成式:
- 集合生成式格式和列表生成式类似,不过用的是大括号:
1
2
|
s1 = {x for x in range ( 10 )} print (s1) |
生成器:
- 生成器是一种迭代过程才生成对应元素的可迭代对象
- 生成器的元素在访问前不会生成,只有当访问时才会生成,如果继续向后访问,那么当前的元素会销毁。
- 生成器的一种生成方式是将列表生成式改为小括号包裹:
1
2
3
4
|
<font face = "Verdana" > print ( "-----使用()列表生成式生成generator------" < / font><font face = "Verdana" >) g = (x * x for x in range ( 10 < / font><font face = "Verdana" >)) print < / font><font face = "Verdana" >( type (g),g) print ( next (g), next (g), next (g))< / font> |
- 生成器本质上是一个函数
-
当一个生成器被调用时,它返回一个生成器对象,而不用执行该函数。 当第一次调用
next()
方法时,函数向下执行,如果遇到yield则返回yield 后面的
值。 再次调用next()
方法时,函数从上次结束的位置继续向下执行,如果遇到yield则返回yield 后面的
值。 - 可以使用yield来定义一个生成器:
1
2
3
4
5
6
7
8
9
10
11
12
|
print ( "\n----使用yield生成generator-------" ) def ge(): print ( "第一次yield" ) yield 1 print ( "第二次yield" ) yield 2 print ( "第三次yield" ) yield 3 o = ge() print ( next (o)) print ( next (o)) print ( next (o)) |
----使用yield生成generator-------
第一次yield
1
第二次yield
2
第三次yield
3
- 生成器本质上是一个函数,如果想要获取这个函数的返回值,我们需要使用异常捕获来获取这个返回值:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
def fib( max ): n,a,b = 0 , 0 , 1 while n < max : yield b a,b = b,a + b n = n + 1 return 'done' print ( "\n-----尝试获得函数返回值------" ) gg = fib( 6 ) while True : try : x = next (gg) print ( "g:" ,x) except StopIteration as e: print ( '返回值等于:' ,e.value) break |
- 既可以使用next()来迭代生成器,也可以使用for来迭代:
1
2
3
4
5
6
7
8
9
10
11
12
|
def ge(): print ( "第一次yield" ) yield 1 print ( "第二次yield" ) yield 2 print ( "第三次yield" ) yield 3 o = ge() print ( "\n---迭代generator的方法--------" ) for x in o: print (x) #相当于进入到generator函数中,执行下去并得到返回值 |
---迭代generator的方法--------
第一次yield
1
第二次yield
2
第三次yield
3
- 由于生成器的特性,可以进行”协程“操作:后续补充
希望本文所述对大家Python程序设计有所帮助。
原文链接:https://www.cnblogs.com/progor/p/8414550.html