enumerate:追踪索引
在遍历一个序列的时候,我们往往想追踪该元素在序列中的索引。使用enumerate可以做到这点。
该方法一般用来构建一个字典
a = ['a', 'b', 'c', 'd', 'e', 'a', 'b']
mapping = {}
for index, value in enumerate(a):
mapping[value] = index
print(mapping)
# {'a': 5, 'b': 6, 'c': 2, 'd': 3, 'e': 4}
可以看到,如果序列中出现重复的元素,则该元素的索引为最后一个重复元素的索引(这是因为后来的索引把前一个的覆盖了)
.
zip:元素配对
zip可以将多个序列的元素配对,新建一个元组构成的列表
a = ['I', 'lo', 'y']
b = ['', 've', 'ou']
zipped = zip(a, b)
print(list(zipped))
# [('I', ''), ('lo', 've'), ('y', 'ou')]
值得注意的是,zip方法生成的是一个zip对象,不能直接用print输出哈
另外,zip可以处理任意长度的序列,生成的列表长度由最短的序列决定:
a = ['I', 'lo', 'y']
b = ['', 've', 'ou']
c = ['yi', 'lan']
zipped = zip(a, b, c)
print(tuple(zipped))
# (('I', '', 'yi'), ('lo', 've', 'lan'))
对于已“配对”的序列,zip也可以去“拆分”该序列:
merge = [('I', ''), ('lo', 've'), ('y', 'ou')]
a, b = zip(*merge)# 语法为zip(*拆分对象)
print(a) # ('I', 'lo', 'y')
print(b) # ('', 've', 'ou')
.
reversed:倒序排列
reversed方法很简单,将原序列倒序排列
a = [1, 2, 3, 4]
print(reversed(a))
# <list_reverseiterator object at 0x0000021DB709FB48>
print(list(reversed(a)))
# [4, 3, 2, 1]
值得注意的是,reversed是一个生成器,如果没有实例化(例如用list函数等),它不会产生一个倒序排列。
chou_shun 发布了11 篇原创文章 · 获赞 1 · 访问量 426 私信 关注