![](/img/trans.png)
[英]How to group elements in python by n elements without list slicing?
[英]Skipping n elements iteratively while slicing a list in python
我有一个包含 10573 个元素的大数组,我想将它们分组为块,但在每个块之后跳过两个元素。
我有将列表分成块的代码:
chunk_size= 109
for i in range(0, len(ints), chunk_size):
chunk = ints[i:i+chunk_size]
但是我如何迭代地跳过或删除大列表中的两个元素,即在达到每个大小为 109 的块之后?
有没有办法做到这一点?
在迭代中使用时将块大小加 2。
chunk_size= 109
for i in range(0, len(ints), chunk_size+2):
chunk = ints[i:i+chunk_size]
使用模运算:
blocksize = chuncksize + 2
newints = [i for i in ints if i%blocksize < chuncksize]
另一种方法是向后循环:
blocksize = chuncksize + 2
for i in range(len(ints), 0, -blocksize)
ints.pop(i+chuncksize)
ints.pop(i+chuncksize+1)
注意:没有测试。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.