在numpy蒙版_数组中用nan替换蒙版

在numpy蒙版_数组中用nan替换蒙版,numpy,masked-array,Numpy,Masked Array,我想用nan替换masked结果。有没有一种方法可以直接用numpy的掩蔽数组?我想你可以做np.ones >> masks = [[1,1],[0,0]] >> [np.ma.masked_array(data=np.array([1.0,2.0]), mask=m, fill_value=np.nan).mean() for m in masks] [masked, 1.5] filled方法将屏蔽值替换为填充值: In [232]: M = np.m

我想用
nan
替换
masked
结果。有没有一种方法可以直接用numpy的
掩蔽数组

我想你可以做
np.ones

>> masks = [[1,1],[0,0]]    
>> [np.ma.masked_array(data=np.array([1.0,2.0]), mask=m, fill_value=np.nan).mean() for m in masks]
   [masked, 1.5]
filled
方法将屏蔽值替换为填充值:

In [232]: M = np.ma.masked_array(data=np.array([1.0,2.0]),mask=[True, False])
或者,在定义数组时指定填充值:

In [233]: M.filled()                                                         
Out[233]: array([1.e+20, 2.e+00])
In [234]: M.filled(np.nan)         # or with a value of your choice.                                                   
Out[234]: array([nan,  2.])
蒙版平均值方法跳过填充值:

In [235]: M = np.ma.masked_array(data=np.array([1.0,2.0]),mask=[True, False],
     ...:  fill_value=np.nan)                                                
In [236]: M                                                                  
Out[236]: 
masked_array(data=[--, 2.0],
             mask=[ True, False],
       fill_value=nan)
In [237]: M.filled()                                                         
Out[237]: array([nan,  2.])
In [235]: M = np.ma.masked_array(data=np.array([1.0,2.0]),mask=[True, False],
     ...:  fill_value=np.nan)                                                
In [236]: M                                                                  
Out[236]: 
masked_array(data=[--, 2.0],
             mask=[ True, False],
       fill_value=nan)
In [237]: M.filled()                                                         
Out[237]: array([nan,  2.])
In [238]: M.mean()                                                           
Out[238]: 2.0
In [239]: M.filled().mean()                                                  
Out[239]: nan
In [241]: np.nanmean(M.filled())    # so does the `nanmean` function
In [242]: M.data.mean()             # mean of the underlying data                                                      
Out[242]: 1.5