我们可以编写一个函数来比较两个序列是否相等,然后根据需要将其扩展到比较任意数量和类型的序列。以下是一个方案:
from collections.abc import Sequence
def compare_sequences(seq1, seq2):
if isinstance(seq1, Sequence) and isinstance(seq2, Sequence):
if len(seq1) != len(seq2):
return False
for item1, item2 in zip(seq1, seq2):
if not compare_sequences(item1, item2):
return False
return True
else:
return seq1 == seq2
该函数接受任意两个序列作为参数,并返回一个布尔值,指示它们是否相等。如果它们的长度不同,则它们不相等。否则,我们使用zip函数对它们的每个元素进行迭代,递归调用函数本身来比较每个元素。如果有任何元素不相等,则返回False。如果所有元素都相等,则返回True。
该函数可以比较各种类型的序列,包括嵌套的序列(例如列表的列表)和自定义的序列类。在使用自定义序列类时,我们需要确保该类继承了collections.abc.Sequence或实现了 __len__和__getitem__方法,以满足Sequence的最低要求。
以下是一些示例:
>>> compare_sequences([1, 2, 3], [1, 2, 3])
True
>>> compare_sequences([1, 2, 3], [1, 2, 4])
False
>>> compare_sequences([[1, 2], [3, 4]], [[1, 2], [3, 4]])
True
>>> compare_sequences((1, 2, 3), [1, 2, 3])
True
>>> compare_sequences(MyList([1, 2, 3]), [1, 2, 3])
True
上一篇:比较选择中的日期是否在将来。
下一篇:比较循环数组中的元素(Java)