pandas dataframe pivot_table

本文详细介绍如何使用 Pandas 的 pivot_table 函数进行数据透视,包括按月、按年和按天聚合数据的方法,以及如何计算总和和平均值。通过实例展示了数据重塑和聚合的强大功能。

一个比较有代表性的例子 参考官网

df=pd.DataFrame({
    "value":np.random.randn(36)
},
index=pd.date_range('2011-01-01',freq='M',periods=36))
print(df)

结构如下:

dff=pd.pivot_table(df,index=df.index.month,columns=df.index.year,
                   values='value',
                   # aggfunc='mean'
                   )

print(dff)
dff=pd.pivot_table(df,index=df.index.month,columns=df.index.year,
                   values='value',
                   aggfunc='sum'
                   )

print(dff)

结构如下:

df1=pd.pivot_table(df,index=df.index.year,values='value', columns=df.index.month,aggfunc='sum')
print(df1)
print(df1.sum())
print(df1.sum(axis=1))
df1['sum']=df1.sum(axis=1)
df1.loc['newr']= df1.sum()
print(df1)

 

df=pd.pivot_table(df,index=df.index.day,values='value',columns=df.index.month)
print(df)

 

源码:

import pandas as pd
import numpy as np

df=pd.DataFrame({
    "value":np.random.randn(36)
},
index=pd.date_range('2011-01-01',freq='M',periods=36))
print(df)

dff=pd.pivot_table(df,index=df.index.month,columns=df.index.year,
                   values='value',
                   # aggfunc='mean'
                   )

print(dff)
dff=pd.pivot_table(df,index=df.index.month,columns=df.index.year,
                   values='value',
                   aggfunc='sum'
                   )

print(dff)
df1=pd.pivot_table(df,index=df.index.year,values='value', columns=df.index.month,aggfunc='sum')
print(df1)
print(df1.sum())
print(df1.sum(axis=1))
df1['sum']=df1.sum(axis=1)
df1.loc['newr']= df1.sum()
print(df1)
df2=pd.pivot_table(df,index=df.index.year,values='value', aggfunc='mean')
print(df2)

print("*"*22)
df=pd.pivot_table(df,index=df.index.day,values='value',columns=df.index.month)
print(df)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值