首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在python中跳过特定范围的列表

在python中跳过特定范围的列表
EN

Stack Overflow用户
提问于 2022-06-04 04:22:52
回答 5查看 180关注 0票数 7

我有一个数组,我想要选择前2或范围,跳过下一个2,选择下一个2,然后继续到列表的末尾。

代码语言:javascript
复制
list = [2, 4, 6, 7, 9,10, 13, 11, 12,2]
results_wanted = [2,4,9,10,12,2] # note how it skipping 2. 2 is used here as and example

在python中有实现这个目标的方法吗?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2022-06-04 04:35:57

获取元素的n数并跳过下一个n

代码语言:javascript
复制
l = [2, 4, 6, 7, 9, 10, 13, 11, 12, 2]
n = 2
wanted = [x for i in range(0, len(l), n + n) for x in l[i: i + n]]
### Output : [2, 4, 9, 10, 12, 2]
票数 4
EN

Stack Overflow用户

发布于 2022-06-04 04:34:34

代码语言:javascript
复制
from itertools import compress, cycle

results = list(compress(lst, cycle([1,1,0,0])))

代码语言:javascript
复制
results = [x for i, x in enumerate(lst) if i % 4 < 2]

或者,如果不再需要原始列表,所以可以修改它而不是构建新列表(如果您确实想要一个新的列表,您仍然可以在副本上使用这个列表):

代码语言:javascript
复制
del lst[2::4], lst[2::3]

包含一百万元素列表的基准:

代码语言:javascript
复制
  8.6 ms ± 0.1 ms _del_slices
 11.6 ms ± 0.1 ms _compress_bools
 13.6 ms ± 0.0 ms _compress_ints
 14.1 ms ± 0.0 ms _copy_del_slices
 22.6 ms ± 0.2 ms _copy_slices
 46.0 ms ± 0.2 ms Black_Raven
 59.5 ms ± 0.4 ms Vikrant_Sharma
 84.8 ms ± 0.1 ms _enumerate_modulo
161.8 ms ± 0.6 ms RCvaram

不包括numpy解决方案,因为为此我必须切换到一个较旧的Python版本,而且比较没有意义(np.array(lst)已经使用了55 ms)。

基准代码(在网上试试!):

代码语言:javascript
复制
def _compress_ints(lst):
    return list(compress(lst, cycle([1,1,0,0])))

def _compress_bools(lst):
    return list(compress(
        lst,
        cycle(chain(repeat(True, 2),
                    repeat(False, 2)))
    ))

def _enumerate_modulo(lst):
    return [x for i, x in enumerate(lst) if i % 4 < 2]

def _del_slices(lst):
    del lst[2::4], lst[2::3]
    return lst

def _copy_del_slices(lst):
    results = lst[:]
    del results[2::4], results[2::3]
    return results

def _copy_slices(lst):
    a = lst[::4]
    b = lst[1::4]
    results = [None] * (len(a) + len(b))
    results[::2] = a
    results[1::2] = b
    return results
    
def Black_Raven(list1):
    add = skip = 2
    list2 = []
    for i in range(0, len(list1), skip+add):
        list2 += list1[i:i+add]
    return list2

def Vikrant_Sharma(l):
    n = 2
    return [x for i in range(0, len(l), n + n) for x in l[i: i + n]]

def RCvaram(test):
        skip = 2
        desireList = []
        skipMode = False
        for i in range(0,len(test)):
            if skipMode==False:
                desireList.append(test[i])
            if (i+1)%skip==0:
                skipMode=not skipMode
        return desireList

funcs = [_compress_ints, _compress_bools, _enumerate_modulo, _del_slices, _copy_del_slices, _copy_slices, Black_Raven, Vikrant_Sharma, RCvaram]

from timeit import default_timer as timer
from itertools import compress, cycle, repeat, chain, islice
from random import shuffle
from statistics import mean, stdev
import gc

# Correctness
lst = [2, 4, 6, 7, 9,10, 13, 11, 12,2]
results_wanted = [2,4,9,10,12,2]
for func in funcs:
    assert func(lst[:]) == results_wanted
for n in range(100):
    lst = list(range(n))
    expect = funcs[0](lst[:])
    for func in funcs:
        assert func(lst[:]) == expect, func.__name__

# Speed
times = {func: [] for func in funcs}
def stats(func):
    ts = [t * 1e3 for t in sorted(times[func])[:3]]
    return f'{mean(ts):5.1f} ms ± {stdev(ts):.1f} ms'
original = list(range(1000000))
for _ in range(15):
    shuffle(funcs)
    for func in funcs:
        lst = original.copy()
        gc.collect()
        t0 = timer()
        result = func(lst)
        t = timer() - t0
        del result
        times[func].append(t)
for func in sorted(funcs, key=stats):
    print(stats(func), func.__name__)
票数 7
EN

Stack Overflow用户

发布于 2022-06-04 04:33:30

我没有使用任何python预构建技术。我使用了传统的for循环和if-否则条件。

  1. 我们必须根据一个特定的数字跳过。
  2. 这种跳过需要基于布尔参数,我将其定义为skipMode。
  3. 如果skipMode为真,那么数字将不会添加到列表4中,这个skipMode将根据skipNumber进行更改。
代码语言:javascript
复制
test = [2, 4, 6, 7, 9,10, 13, 11, 12,2]

def skipElementsByPositions(test,skip):
    if(skip> len(test)):
        return -1
    else:
        desireList = []
        skipMode = False
        for i in range(0,len(test)):
            if skipMode==False:
                desireList.append(test[i])
            if (i+1)%skip==0:
                skipMode=not skipMode
        return desireList

print(skipElementsByPositions(test,2)) #2,4,9,10,12,2
print(skipElementsByPositions(test,3)) #2, 4, 6, 13, 11, 12
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72497046

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档