【问题标题】:Python Pandas Pivot TablePython Pandas 数据透视表
【发布时间】:2012-03-03 23:42:13
【问题描述】:

我正在尝试使用 Pandas 制作频率计数数据透视表。

我有以下代码:

 from pandas import pivot_table, DataFrame, crosstab
 import numpy as np
 df=DataFrame(
    {'Y':[99999991, 99999992, 99999993, 99999994, 99999995,
          99999996, 99999997, 99999998, 99999999],
     'X':[1, 2, 3, 4, 5, 6, 7, 8, 9],
     'X2':[1, 2, 3, 4, 5, 6, 7, 8, 9]})
 print pivot_table(df,rows=['Y'], cols=['X'],aggfunc=np.sum)

这是我的输出:

 X          1   2   3   4   5   6   7   8   9
 Y                                         
  99999991   1 NaN NaN NaN NaN NaN NaN NaN NaN
  99999992 NaN   2 NaN NaN NaN NaN NaN NaN NaN
  99999993 NaN NaN   3 NaN NaN NaN NaN NaN NaN
  99999994 NaN NaN NaN   4 NaN NaN NaN NaN NaN
  99999995 NaN NaN NaN NaN   5 NaN NaN NaN NaN
  99999996 NaN NaN NaN NaN NaN   6 NaN NaN NaN
  99999997 NaN NaN NaN NaN NaN NaN   7 NaN NaN
  99999998 NaN NaN NaN NaN NaN NaN NaN   8 NaN
  99999999 NaN NaN NaN NaN NaN NaN NaN NaN   9

这是我想要的输出:

 X          1   2   3   4   5   6   7   8   9
 X2                                         
   1   99999991 NaN NaN NaN NaN NaN NaN NaN NaN
   2 NaN   99999992 NaN NaN NaN NaN NaN NaN NaN
   3 NaN NaN   99999993 NaN NaN NaN NaN NaN NaN
   4 NaN NaN NaN   99999994 NaN NaN NaN NaN NaN
   5 NaN NaN NaN NaN   99999995 NaN NaN NaN NaN
   6 NaN NaN NaN NaN NaN   99999996 NaN NaN NaN
   7 NaN NaN NaN NaN NaN NaN   99999997 NaN NaN
   8 NaN NaN NaN NaN NaN NaN NaN   99999998 NaN
   9 NaN NaN NaN NaN NaN NaN NaN NaN   99999999

这是我不断得到的:

<class 'pandas.core.frame.DataFrame'>
Int64Index: 9 entries, 1 to 9
Data columns:
('Y', 1L)    1  non-null values
('Y', 2L)    1  non-null values
('Y', 3L)    1  non-null values
('Y', 4L)    1  non-null values
('Y', 5L)    1  non-null values
('Y', 6L)    1  non-null values
('Y', 7L)    1  non-null values
('Y', 8L)    1  non-null values
('Y', 9L)    1  non-null values
dtypes: float64(9)

有人知道为什么吗?是不是输出太大了。我似乎在上面找不到任何东西。

【问题讨论】:

    标签: python python-2.7 pivot-table pandas


    【解决方案1】:

    只需将rows=['Y'] 替换为rows=['X2']

    >>> print pivot_table(df,rows=['X2'], cols=['X'],aggfunc=np.sum)
          Y                                        
    X     1    2    3    4    5    6    7    8    9
    X2                                             
    1   101  NaN  NaN  NaN  NaN  NaN  NaN  NaN  NaN
    2   NaN  102  NaN  NaN  NaN  NaN  NaN  NaN  NaN
    3   NaN  NaN  103  NaN  NaN  NaN  NaN  NaN  NaN
    4   NaN  NaN  NaN  104  NaN  NaN  NaN  NaN  NaN
    5   NaN  NaN  NaN  NaN  105  NaN  NaN  NaN  NaN
    6   NaN  NaN  NaN  NaN  NaN  106  NaN  NaN  NaN
    7   NaN  NaN  NaN  NaN  NaN  NaN  107  NaN  NaN
    8   NaN  NaN  NaN  NaN  NaN  NaN  NaN  108  NaN
    9   NaN  NaN  NaN  NaN  NaN  NaN  NaN  NaN  109
    

    【讨论】:

    • 谢谢!我编辑了这个问题,因为我认为它取决于数字,我无法接收上述格式的数据,你知道为什么吗?
    • 该输出是预期行为。您是否阅读过这部分文档:pandas.sourceforge.net/reshaping.html
    【解决方案2】:

    试试这个:

    In [3]: df.pivot_table('Y', rows='X', cols='X2')
    X2         1         2         3         4         5         6         7         8         9
    X                                                                                           
    1   99999991       NaN       NaN       NaN       NaN       NaN       NaN       NaN       NaN
    2        NaN  99999992       NaN       NaN       NaN       NaN       NaN       NaN       NaN
    3        NaN       NaN  99999993       NaN       NaN       NaN       NaN       NaN       NaN
    4        NaN       NaN       NaN  99999994       NaN       NaN       NaN       NaN       NaN
    5        NaN       NaN       NaN       NaN  99999995       NaN       NaN       NaN       NaN
    6        NaN       NaN       NaN       NaN       NaN  99999996       NaN       NaN       NaN
    7        NaN       NaN       NaN       NaN       NaN       NaN  99999997       NaN       NaN
    8        NaN       NaN       NaN       NaN       NaN       NaN       NaN  99999998       NaN
    9        NaN       NaN       NaN       NaN       NaN       NaN       NaN       NaN  99999999
    

    这也可以:

    pivot_table(df, 'Y', rows='X', cols='X2')
    

    pivot_table(df, rows='X', cols='X2')['Y']
    

    【讨论】:

      猜你喜欢
      • 2023-03-23
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2014-04-27
      • 1970-01-01
      • 1970-01-01
      • 2021-01-20
      • 2021-01-17
      相关资源
      最近更新 更多