【要点抢先看】

1.range函数:返回一系列连续增加的整数
2.zip函数:并行迭代多个序列
3.enumerate函数:同时产生偏移和元素

今天我们来讲讲三种循环迭代的常用技巧,range、zip和enumerate

内置函数range:用来返回一系列连续增加的整数

这个函数产生的连续增加的整数序列,可以作为for循环迭代的索引

for x in range(5):
    print(x, end=',')

0,1,2,3,4,
复制代码

range也可以用在任何需要整数列表的地方。直接打印range函数的返回值是不能直接返回一个整数列表的,如果将其作为一个参数传给list函数,则可以一次性显示全部结果。

print(range(5))

range(0, 5)
复制代码

-

print(list(range(-5,5)))

[-5, -4, -3, -2, -1, 0, 1, 2, 3, 4]
复制代码

内置函数range在for循环中是最常用的,它提供了一种简单的方法,重复特定次数的动作。

当然还可以做一些定制工作,比如在遍历的过程中跳过一些元素。例如每隔一个元素对字符串进行遍历:

S = 'abcdefghijklmn'
for i in range(0,len(S),2):
    print(S[i], end=',')

a,c,e,g,i,k,m,
复制代码

当然,这只是一个示例,我们之前提到过的分片表达式才是实现该功能的最简单的方法,这个我们之前是介绍过的:

S = 'abcdefghijklmn'
for c in S[::2]:
    print(c, end=',')

a,c,e,g,i,k,m,
复制代码

和文件迭代一样,这里range函数的优点也是明显的,它没有复制字符串,不会在python中再创建一个字符串列表,这对于很大的字符串来说,会节约不少空间。

zip:用来并行迭代多个序列

内置zip函数允许我们使用for循环来并行迭代多个序列。zip使用多个序列作为参数,然后返回元组的列表,将这些序列中的并排元素一一配对。

L1 = [1,2,3,4,5]
L2 = ['A','B','C','D','E']
for t in zip(L1,L2):
    print(t, end=',')

(1, 'A'),(2, 'B'),(3, 'C'),(4, 'D'),(5, 'E'),
复制代码

和range一样,zip在遍历时也是依次按需产生结果,而不是一次性显示所有结果

L1 = [1,2,3,4,5]
L2 = ['A','B','C','D','E']

print(zip(L1,L2))

<zip object at 0x000000000260ED08>
复制代码

同样的,如果想一次性显示所有结果,则必须将其包含在一个list调用中,以便一次性显示所有结果

L1 = [1,2,3,4,5]
L2 = ['A','B','C','D','E']
print(list(zip(L1,L2)))

[(1, 'A'), (2, 'B'), (3, 'C'), (4, 'D'), (5, 'E')]
复制代码

最后只说明一点,当zip的多个参数长度不同时,zip会以最短序列的长度为准来截断所得到的元组

L1 = [1,2,3,4,5]
L2 = ['A','B','C']
print(list(zip(L1,L2)))

[(1, 'A'), (2, 'B'), (3, 'C')]
复制代码

回顾一下,之前我们谈到过,当字典的键和值必须在运行时计算产生时,zip函数可以用于产生这样的字典

keys = ['A', 'B', 'C']
vals = [1, 2, 3]
D = dict(zip(keys,vals))
print(D)

{'C': 3, 'A': 1, 'B': 2}
复制代码

enumerate:用来同时产生偏移和元素

有时我们在遍历的时候,既需要偏移值,又需要对应元素,那么内置函数enumerate就可以实现这个功能。

他在for循环的条件下每轮迭代返回一个包含偏移值和偏移元素的元组:(index,value)

S = 'spam'
for t in enumerate(S):
    print(t,end=' ')

(0, 's') (1, 'p') (2, 'a') (3, 'm')
复制代码

同样,他也是按需产生,而非一次性产生所有元素的列表

S = 'spam'
print(enumerate(S))

<enumerate object at 0x0000000001ED2558>
复制代码

【妹子说】这种高级技巧课程的内容还是挺多的,需要多多练习才能好好掌握~