zip()并行迭代

使用zip()并行迭代

我们可以通过zip()函数对多个序列进行并行迭代,zip()函数在最短序列‘用完’时就会停止。

【操作】测试zip()并行迭代

names=['勒布朗','kd','凯文','ad']
ages=[35,30,33]
citys=['洛杉矶','布鲁克林','骑士','迈阿密']


for name,age,city in zip(names,ages,citys):
    print("{0}-{1}-{2}".format(name,age,city))


for i in range(3):
    print("{0}-{1}-{2}".format(names[i],ages[i],citys[i]))

推导式创建序列

推导式是一个或者多个迭代器快速创建序列的一种方法。他可以将循环和条件判断结合,从而避免冗长的代码。推导式是典型的python风格,会使用他代表已经超过python初学者的水平。

列表式推导

列表推导式生成列表对象,语法如下:

[表达式 for item in 可迭代对象]  或者 {表达式 for item in 可迭代对象 if 条件判断}

>>> [x for x in range(5)]
[0, 1, 2, 3, 4]

>>> [x*2 for x in range(1,5)]
[2, 4, 6, 8]

>>> [x*2 for x in range(1,20) if x%2==0]
[4, 8, 12, 16, 20, 24, 28, 32, 36]

>>> [a for a in 'abcdef']
['a', 'b', 'c', 'd', 'e', 'f']

cells = [(col,row) for col in range(1,11) for row in range (1,11)] #可以使用两个循环
for cell in cells:
    print(cell)

字典推导式

字典的推导式生成字典对象,格式如下:

{key_expression:value_expression for 表达式 in 可迭代对象}

类似于列表推导式,字典推导也可以增加if条件判断、多个for循环。

统计文本中字符出现的次数:

方法一推导式:

my_text = 'i love you, i love beijing, i love you'
char_count ={c:my_text.count(c) for c in my_text}
print(char_count)

方法二普通循环:

char_count = {}
my_text = 'i love you, i love beijing, i love you'

for c in my_text:
    char_count[c]=my_text.count(c)
print(char_count)

集合推导式

集合推导式生成集合,和列表推导式的语法格式类似:

{表达式 for item in 可迭代对象}

或者 

{表达式 for item in 可迭代对象 if 条件判断}

>>> {x for x in range(1,100) if x % 9 ==0}
{99, 36, 72, 9, 45, 81, 18, 54, 90, 27, 63}

生成器推到式(生成元组)

>>> (x for x in range(8))
<generator object <genexpr> at 0x105792740>
我们发现提示的是‘生成器对象’。显然,元组是没有推导式的。

一个生成器只能运行一次,第一次迭代可以得到数据,第二次迭代发现数据已经没有了

gnt = (x for x in range(1,99) if x % 9==0)

print(tuple(gnt))
print(tuple(gnt))

 

posted @ 2021-04-12 18:02  小白自学python  阅读(90)  评论(0编辑  收藏  举报