Пример:
from __future__ import division
import numpy as np
n = 8
"""masking lists"""
lst = range(n)
print lst
# the mask (filter)
msk = [(el>3) and (el<=6) for el in lst]
print msk
# use of the mask
print [lst[i] for i in xrange(len(lst)) if msk[i]]
"""masking arrays"""
ary = np.arange(n)
print ary
# the mask (filter)
msk = (ary>3)&(ary<=6)
print msk
# use of the mask
print ary[msk] # very elegant
и результаты:
>>>
[0, 1, 2, 3, 4, 5, 6, 7]
[False, False, False, False, True, True, True, False]
[4, 5, 6]
[0 1 2 3 4 5 6 7]
[False False False False True True True False]
[4 5 6]
Как видите, операция маскирования массива более элегантна по сравнению со списком. Если вы попытаетесь использовать схему маскирования массива из списка, вы получите ошибку :
>>> lst[msk]
Traceback (most recent call last):
File "<interactive input>", line 1, in <module>
TypeError: only integer arrays with one element can be converted to an index
. Вопрос в том, чтобы найти элегантную маскировку для list
s.
Обновления:
Ответ jamylak
был принят для введения compress
, однако моменты, упомянутые в Joel Cornett
, сделали решение полным до желаемой формы, которая меня интересует.
>>> mlist = MaskableList
>>> mlist(lst)[msk]
>>> [4, 5, 6]