我有一个NumPy
矩阵,如下所示:
[[182 93 107 ..., nan nan -1]
[182 93 107 ..., nan nan -1]
[182 93 110 ..., nan nan -1]
...,
[188 95 112 ..., nan nan -1]
[188 97 115 ..., nan nan -1]
[188 95 112 ..., nan nan -1]]
我想从上面的矩阵中删除只涉及nan
值的列。
我该怎么做?感谢。
答案 0 :(得分:5)
假设您的数组现在为float
,您可以识别所有NaN列并使用花式索引来检索其他列:
d
array([[ 182., 93., 107., nan, nan, -1.],
[ 182., 93., 107., 4., nan, -1.],
[ 182., 93., 110., nan, nan, -1.],
[ 188., 95., 112., nan, nan, -1.],
[ 188., 97., 115., nan, nan, -1.],
[ 188., 95., 112., nan, nan, -1.]])
d[:,~np.all(np.isnan(d), axis=0)]
array([[ 182., 93., 107., nan, -1.],
[ 182., 93., 107., 4., -1.],
[ 182., 93., 110., nan, -1.],
[ 188., 95., 112., nan, -1.],
[ 188., 97., 115., nan, -1.],
[ 188., 95., 112., nan, -1.]])