我需要知道在python中是否存在一个函数或本机库,它允许我在列表中循环的次数多于列表中元素的数量.换句话说,当我感兴趣的索引大于列表大小时,下一个元素是列表的第一个元素.
例如,我有这个列表:
abc = ['a','b','c','d','e' ]
所以,如果我有一个值为10的参数,结果是’a’.如果值为18的参数为“d”.
谢谢!
问候!
最佳答案
最简单:用模数包装索引
>>> abc = ['a','e' ]
>>> abc[18 % len(abc)]
'd'
如果需要,可以将其包装在辅助类中:
>>> class ModList(list):
... def __getitem__(self,item):
... if isinstance(item,slice):
... return super().__getitem__(item)
... return super().__getitem__(item % len(self))
...
>>> abc = ModList('abcde')
>>> abc[18]
'd'
>>> abc[-5]
'a'
>>> abc[-6]
'e'
您可能希望类似地实现__setitem__和__delitem__.