我需要知道在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__.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。