你的阵列是一个object阵列,这意味着数组中的元素是任意Python对象。 Pandas使用对象数组,所以很可能当你将Pandas DataFrame转换为一个numpy数组时,结果就是一个对象数组。 nanmax()不能正确处理对象数组。
这里有几个例子,一个使用numpy.matrix和一个numpy.ndarray。随着matrix,你得到所有的东西没有警告了问题:
In [1]: import numpy as np
In [2]: m = np.matrix([[2.0, np.nan, np.nan]], dtype=object)
In [3]: np.nanmax(m)
Out[3]: nan
使用数组,你会得到一个神秘的警告,但仍会返回nan:
In [4]: a = np.array([[2.0, np.nan, np.nan]], dtype=object)
In [5]: np.nanmax(a)
/Users/warren/miniconda3scipy/lib/python3.5/site-packages/numpy/lib/nanfunctions.py:326: RuntimeWarning: All-NaN slice encountered
warnings.warn("All-NaN slice encountered", RuntimeWarning)
Out[5]: nan
你可以,如果确定您的数组是一种对象数组。当您在交互式python或ipython shell中显示数组时,您会看到dtype=object。或者你可以检查a.dtype;如果a是对象数组,则会看到dtype('O')或object(取