一个列表:
a = ['a', 'b', 'c', 3, 4, 'd', 6, 7, 8]
我想要一个使用 using 子集的列表a[0:2],a[4], a[6:]
,
那就是我想要一个清单['a', 'b', 4, 6, 7, 8]
认为
a = ['a', 'b', 'c', 3, 4, 'd', 6, 7, 8]
并且索引列表存储在
b= [0, 1, 2, 4, 6, 7, 8]
那么一个简单的单线解决方案将是
c = [a[i] for i in b]
试试new_list = a[0:2] + [a[4]] + a[6:]
。
或者更一般地说,是这样的:
from itertools import chain
new_list = list(chain(a[0:2], [a[4]], a[6:]))
这也适用于其他序列,并且可能更快。
或者你可以这样做:
def chain_elements_or_slices(*elements_or_slices):
new_list = []
for i in elements_or_slices:
if isinstance(i, list):
new_list.extend(i)
else:
new_list.append(i)
return new_list
new_list = chain_elements_or_slices(a[0:2], a[4], a[6:])
但请注意,如果列表中的某些元素本身就是列表,这会导致问题。要解决此问题,请使用先前的解决方案之一,或替换a[4]
为a[4:5]
(或更一般地a[n]
为a[n:n+1]
)。
以下定义可能比提出的第一个解决方案更有效
def new_list_from_intervals(original_list, *intervals):
n = sum(j - i for i, j in intervals)
new_list = [None] * n
index = 0
for i, j in intervals :
for k in range(i, j) :
new_list[index] = original_list[k]
index += 1
return new_list
然后你可以像下面这样使用它
new_list = new_list_from_intervals(original_list, (0,2), (4,5), (6, len(original_list)))