一日一技:不等长度列表的同时迭代

简介: 一日一技:不等长度列表的同时迭代

有两个列表 [1,2,3]['a','b','c'],当我们想对他们同时迭代的时候,可以这样写:

a = [1, 2, 3]
b = ['a', 'b', 'c']
for pair in zip(a, b):
    print(pair)

运行效果如下图所示:

这种用法相信大家都已经知道了。

现在问题来了,有两个序列: [1,2,3]['a','b','c','d','e'],如果我继续使用 zip对他们进行迭代,会发现 de丢失了:

如果我们把 a, b交换一下位置,会发现依然没有 d, e,如下图所示:

如果我想实现的把整个 ['a','b','c','d','e']都遍历完,并且 [1,2,3]缺的部分使用 NA代替,应该怎么办呢?

此时可以使用: zip_longest:

from itertools import zip_longest
a = [1, 2, 3]
b = ['a', 'b', 'c', 'd', 'e']
for pair in zip_longest(b, a, fillvalue='NA'):
    print(pair)

运行效果如下图所示:

大家也可以把a,b交换一下位置,可以发现这样也是成立的。自带的zip是基于最短的列表来进行迭代,而zip_longest是以最长的序列来进行迭代。

zip_longest也可以支持多个序列,它会以最长的为准

from itertools import zip_longest
a = [1, 2, 3]
b = ['a', 'b', 'c', 'd', 'e']
c = ['x', 'y', 'z', 'w']
for pair in zip_longest(a, b, c, fillvalue='NA'):
    print(pair)

运行效果如下图所示:

目录
相关文章
|
7月前
|
PHP
在数组中,找出给定数字的出现次数,比如[1,2,3,2,2]中2的出现次数是3次(任意编程语言描述)
在数组中,找出给定数字的出现次数,比如[1,2,3,2,2]中2的出现次数是3次(任意编程语言描述)
47 0
|
7月前
|
算法 测试技术 C#
【位运算 试填法】【推荐】3022. 给定操作次数内使剩余元素的或值最小
【位运算 试填法】【推荐】3022. 给定操作次数内使剩余元素的或值最小
|
7月前
leetcode-5894:至少在两个数组中出现的值
leetcode-5894:至少在两个数组中出现的值
50 0
|
JavaScript Python
从列表中或数组中随机抽取固定数量的元素组成新的数组或列表
从列表中或数组中随机抽取固定数量的元素组成新的数组或列表
74 0
|
存储 算法 JavaScript
设计并实现一个函数, 功能为给定一个存储为随机整数的数组,从中删除所有值为i的整数
设计并实现一个函数, 功能为给定一个存储为随机整数的数组,从中删除所有值为i的整数
|
存储 算法 JavaScript
寻找数组中的重复数字
寻找数组中的重复数字
寻找数组中的重复数字
|
人工智能 算法 JavaScript
最长连续不重复的序列
最长连续不重复的序列
|
算法 Go
算法练习第十题——寻找重复数(不修改数组)
给定一个包含 n + 1 个整数的数组 nums ,其数字都在 [1, n] 范围内(包括 1 和 n),可知至少存在一个重复的整数。
给定一个字符串,能否最多删除一段连续的一段使得剩下的为“2020”
给定一个字符串,能否最多删除一段连续的一段使得剩下的为“2020”
86 0