Łącząc odpowiedzi @jamylak i @ jpaddison3 razem, jeśli chcesz być odporny na tablice numpy jako dane wejściowe i obsługiwać je w taki sam sposób jak listy, powinieneś użyć
import numpy as np
isinstance(P, (list, tuple, np.ndarray))
Jest to odporne na podklasy tablic list, krotek i tablic numpy.
A jeśli chcesz być odporny na wszystkie inne podklasy sekwencji (nie tylko listę i krotkę), użyj
import collections
import numpy as np
isinstance(P, (collections.Sequence, np.ndarray))
Dlaczego warto robić to w ten sposób, isinstancea nie porównywać type(P)z wartością docelową? Oto przykład, w którym tworzymy i badamy zachowanie NewListtrywialnej podklasy listy.
>>> class NewList(list):
... isThisAList = '???'
...
>>> x = NewList([0,1])
>>> y = list([0,1])
>>> print x
[0, 1]
>>> print y
[0, 1]
>>> x==y
True
>>> type(x)
<class '__main__.NewList'>
>>> type(x) is list
False
>>> type(y) is list
True
>>> type(x).__name__
'NewList'
>>> isinstance(x, list)
True
Pomimo xi yporównywanie jako równe, obchodzenie się z nimi typespowodowałoby inne zachowanie. Jednakże, ponieważ xjest to przykład podklasy list, stosując isinstance(x,list)daje pożądane zachowanie i traktuje xi yw ten sam sposób.
type?