Experimente numpy.clip
:
>>> import numpy
>>> a = numpy.arange(-10, 10)
>>> a
array([-10, -9, -8, -7, -6, -5, -4, -3, -2, -1, 0, 1, 2,
3, 4, 5, 6, 7, 8, 9])
>>> a.clip(0, 10)
array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
Você pode prender apenas a metade inferior com clip(0)
.
>>> a = numpy.array([1, 2, 3, -4, 5])
>>> a.clip(0)
array([1, 2, 3, 0, 5])
Você pode prender apenas a metade superior com clip(max=n)
. (Isso é muito melhor do que minha sugestão anterior, que envolvia passar NaN
para o primeiro parâmetro e usar out
para forçar o tipo.):
>>> a.clip(max=2)
array([ 1, 2, 2, -4, 2])
Outra abordagem interessante é usar where
:
>>> numpy.where(a <= 2, a, 2)
array([ 1, 2, 2, -4, 2])
Finalmente, considere a resposta de aix . Eu prefiro clip
para operações simples porque é autodocumentado, mas sua resposta é preferível para operações mais complexas.
numpy
? Você tentou o método de clipe dea
? A função embutidanumpy.clip
me dá o mesmo erro, mas o método não.Outra solução minimalista do Python sem usar numpy:
Não há necessidade de definir funções extras.
rendimentos:
fonte
for
aplica-o a todos os elementos da lista, colocá-lo depois, significa que somente se a condição for atendida ele irá para a lista resultante.i < 0 ? 0 : i
em C) dentro de uma compreensão de lista. Coloque colchetes para torná-lo mais claro[(0 if i < 0 else i) for i in a]
. Colocar o if after está usando a parte do filtro da construção da expressão de lista.[(i) for i in a if i < 0]
retornará apenas uma lista de itens que são menores que zero.E ainda outra possibilidade:
fonte
Aqui está uma maneira de fazer isso em Python sem entorpecer. Crie uma função que retorne o que você deseja e use uma compreensão de lista ou a função de mapa .
fonte