У меня есть массив NumPy следующим образом:
import numpy as np
a = np.array([1, 4, 2, 6, 4, 4, 6, 2, 7, 6, 2, 8, 9, 3, 6, 3, 4, 4, 5, 8])
и постоянное число b = 6
Основано на предыдущем вопросе Я могу сосчитать число c
, которое определяется числом раз, которое элементы в a
меньше, чем b
2 или более раз подряд.
from itertools import groupby
b = 6
sum(len(list(g))>=2 for i, g in groupby(a < b) if i)
, поэтому в этом примере c == 3
Теперь я хотел бы выводить массив каждый раз, когда выполняется условие, а не подсчитывать, сколько раз условие выполняется.
Так что в этом примере правильным выводом будет:
array1 = [1, 4, 2]
array2 = [4, 4]
array3 = [3, 4, 4, 5]
с тех пор:
1, 4, 2, 6, 4, 4, 6, 2, 7, 6, 2, 8, 9, 3, 6, 3, 4, 4, 5, 8 # numbers in a
1, 1, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 0 # (a<b)
^^^^^^^-----^^^^-----------------------------^^^^^^^^^^--- # (a<b) 2+ times consecutively
1 2 3
До сих пор я пробовал разные варианты:
np.isin((len(list(g))>=2 for i, g in groupby(a < b)if i), a)
и
np.extract((len(list(g))>=2 for i, g in groupby(a < b)if i), a)
Но ни один из них не достиг того, что я ищу.Может кто-нибудь указать мне правильные инструменты Python для вывода различных массивов, удовлетворяющих моему условию?