说我有一个清单
Q = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18]
我相信我可以使用扩展切片表示法提取第一个和每第九个值:
Q[::9]
哪个应该给出:
[0,9,18]
但是我怎样才能类似地选择除这些元素之外的所有元素?
说我有一个清单
Q = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18]
我相信我可以使用扩展切片表示法提取第一个和每第九个值:
Q[::9]
哪个应该给出:
[0,9,18]
但是我怎样才能类似地选择除这些元素之外的所有元素?
你是这个意思?
>>> lis = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18]
>>> lis[1::9]
[1, 10]
扩展切片符号:
lis[start : stop : step] #default values : start = 0, stop = len(lis), step = 1
您可以传递自己的值start
(默认使用 0)
更新:
>>> lis = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18]
>>> se = set(range(0, len(lis),9)) #use a list if the lis is not huge.
>>> [x for i,x in enumerate(lis) if i not in se]
[1, 2, 3, 4, 5, 6, 7, 8, 10, 11, 12, 13, 14, 15, 16, 17]
#for your example even this will work:
>>> [x for i,x in enumerate(lis) if i%9 != 0]
[1, 2, 3, 4, 5, 6, 7, 8, 10, 11, 12, 13, 14, 15, 16, 17]
如果您没有重复数字,这是任何数字集合(不一定是连续的)的通用解决方案:
>>> Q = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18]
>>> list(set(Q).difference(Q[::9]))
[1, 2, 3, 4, 5, 6, 7, 8, 10, 11, 12, 13, 14, 15, 16, 17]
>>>
它使用set.difference
s 来获取set
原始列表和要删除的子列表之间的差异。