繁体   English   中英

在pandas DataFrame中查找并​​选择最常用的列数据

[英]find and select the most frequent data of column in pandas DataFrame

我有一个包含以下列的数据框:

file['DirViento']

Fecha
2011-01-01    ENE
2011-01-02    ENE
2011-01-03    ENE
2011-01-04    NNE 
2011-01-05    ENE
2011-01-06    ENE
2011-01-07    ENE
2011-01-08    ENE
2011-01-09    NNE
2011-01-10    ENE
2011-01-11    ENE
2011-01-12    ENE
2011-01-13    ESE
2011-01-14    ENE
2011-01-15    ENE
... 
2011-12-17    ENE
2011-12-18    ENE
2011-12-19    ENE
2011-12-20    ENE
2011-12-21    ENE
2011-12-22    ENE
2011-12-23    ENE
2011-12-24    ENE
2011-12-25    ENE
2011-12-26    ESE
2011-12-27    ENE
2011-12-28     NE
2011-12-29    ENE
2011-12-30    NNE
2011-12-31    ENE
Name: DirViento, Length: 290, dtype: object

该列每日记录每个月的风向。 我正努力争取每个月的主导方向。 要完成此操作,请选择月内最常重复的数据:

file['DirViento'].groupby(lambda x: x.month).value_counts()


1   ENE    23
    NNE     6
    E       1
    ESE     1
2   ENE    21
    NNO     3
    NNE     2
    NE      1
3   ENE    21
    OSO     1
    ESE     1
    SSE     1
4   ENE    21
    NNE     2
    ESE     1
    NNO     1
6   ENE    15
    ESE     2
    SSE     2
    ONO     1
    E       1
7   ENE    22
    ONO     1
    OSO     1
    NE      1
    NNE     1
    NNO     1
8   ENE    23
    NNE     5
    NE      1
    ONO     1
    ESE     1
9   ENE    17
    NNE     7
    ONO     2
    NE      1
    E       1
    ESE     1
    NNO     1
10  ENE    16
    NNE     2
    ESE     2
    NNO     2
    ONO     1
    NE      1
    E       1
11  ENE    13
    NNE     2
    ESE     2
    ONO     1
12  ENE    26
    NNE     3
    NE      1
    ESE     1
Length: 54, dtype: int64

运行以下代码行时

wind_moda=file['DirViento'].groupby(lambda x: x.month).agg(lambda x: stats.mode(x)[0][0])

应该得到这样的东西

     1  ENE    
     2  ENE    
     3  ENE  
     4  ENE
     6  ENE
     7  ENE    
     8  ENE    
     9  ENE
    10  ENE  
    11  ENE
    12  ENE  

但我得到以下内容:

 1          E  
 2        ENE  
 3        ENE  
 4        ENE  
 6          E  
 7        ENE  
 8        ENE  
 9          E  
 10         E  
 11       ENE  
 12       ENE  

为什么12个月中有4个没有考虑到最常见的数据?

难道我做错了什么 ?

有没有想过每月获得最常见的数据?

Pandas 0.15.2有一个DataFrame.mode()方法。 它可能对我这样寻找这个的人有用。

这是文档

编辑:对于价值:

DataFrame.mode()[0]

这并不像(应该)那样简单。

您可能知道,最常见的值的统计术语是“模式”。 Numpy没有内置功能,但scipy确实如此。 像这样导入:

from scipy.stats.mstats import mode

它不仅仅是返回最常见的值, 正如您可以在文档中阅读的那样 ,因此定义一个使用mode来获取最常见值的函数很方便。

f = lambda x: mode(x, axis=None)[0]

现在,使用apply(f)代替value_counts() apply(f) 这是一个例子:

In [20]: DataFrame([1,1,2,2,2,3], index=[1,1,1,2,2,2]).groupby(level=0).apply(f)
Out[20]: 
1    1.0
2    2.0
dtype: object

更新: Scipy的mode不适用于字符串。 对于字符串数据,您需要定义更通用的模式函数。 这个答案可以解决问题

  1. 对于整个数据帧,您可以使用:

     dataframe.mode() 
  2. 对于特定列:

     dataframe.mode()['Column'][0] 

第二种情况在推算价值方面更有用。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM