PHP前端开发

除了拉上外套拉链之外:掌握 Python 中的“zip_longest”

百变鹏仔 3天前 #Python
文章标签 拉链

我敢打赌,您可能遇到过尝试在 python 中压缩两个不同长度的列表而丢失数据的挫败感。
itertools.zip_longest 可以拯救世界。在这里我想探索如何使用zip_longest(),将其与标准zip进行比较,并深入研究它的闪光点的实际场景。

itertools.zip_longest 是什么?

python 中itertools 模块中的zip_longest() 函数允许您压缩多个可迭代对象,并用指定值(默认)填充较短的可迭代对象。这确保了即使迭代的长度不同,也不会丢失数据。

实际例子

考虑这样一个场景:您尝试在教室里为学生安排座位,但学生人数和可用课桌数量不匹配。你要确保每个学生都有座位,并且每个座位都尽可能坐满。

考虑一个例子,其中课桌数量超过学生数量,同时使用 zip()zip_longest().

使用 zip()

students = ['alice', 'bob']desks = ['desk 1', 'desk 2', 'desk 3']# using zip to pair students with desksseating_zip = list(zip(students, desks))print("seating with zip:")for student, desk in seating_zip:    print(f"{student} is assigned to {desk}")

输出:

seating with zip:alice is assigned to desk 1bob is assigned to desk 2

使用zip(),一旦较短的列表(学生)用完,配对就会停止。办公桌 3 仍未分配,并且没有迹象表明它未被使用。

使用 zip_longest()

from itertools import zip_longeststudents = ['alice', 'bob']desks = ['desk 1', 'desk 2', 'desk 3']# using zip_longest to pair students with desksseating_zip_longest = list(zip_longest(students, desks, fillvalue='empty seat'))print("seating with zip_longest:")for student, desk in seating_zip_longest:    print(f"{student} is assigned to {desk}")

输出:

Seating with zip_longest:Alice is assigned to Desk 1Bob is assigned to Desk 2Empty Seat is assigned to Desk 3

使用zip_longest(),即使没有足够的学生来填满所有座位,每张课桌都会被计算在内。在这种情况下,办公桌 3 与“空座”配对,表明该办公桌仍然无人占用。当您需要跟踪所有资源并确保不遗漏任何内容时,此方法特别有用。

?zip_longest()的优点
保留数据:确保填充较短的可迭代对象时不会丢失数据。
灵活性: 允许指定自定义填充值。
全面配对:在需要不同长度迭代的对齐的数据处理任务中很有用。
?zip_longest()的缺点:
填充可能是不需要的:在某些情况下,填充可能会带来不必要的复杂性。
内存使用:如果处理大的可迭代对象和大的填充值,可能会使用更多的内存。

?zip()的优点:
简单高效:适用于等长度的可迭代。
更少的内存使用:无填充意味着潜在的更少的内存开销。
?zip()的缺点:
数据丢失:截断为最短的迭代,丢失较长迭代的数据。

结论

zip_longest() 是 python 武器库中的一个强大工具,特别是在处理不同长度的可迭代时。它通过填充缺失值来确保数据完整性,使其成为各种数据处理任务的理想选择。虽然 zip() 更简单、更节省内存,但 zip_longest() 提供了许多实际场景所需的灵活性。