A pivot table allows you to investigate data aggregated by one or more index columns. There are multiple options for creating a pivot table in pandas. We’ll explore two user-friendly functions: pd.pivot_table() and .groupby().
Let’s say we want to see the amount a greenhouse owner has spent per plant species. We can pivot with aggregation using either
pd.pivot_table(data, index=’plant’, values=’price’, aggfunc=np.sum)
or
data[[‘plant’,’price’]].groupby(by=’plant’).sum()
Either method will output the following:
data:image/s3,"s3://crabby-images/c19b2/c19b2276975e9e93af6a6745cd89eb31119a995e" alt=""
We can also specify a multilevel pivot table using either method.
Checking piv.equals(piv0)
yields True.
Here’s what the resulting DataFrame looks like:
data:image/s3,"s3://crabby-images/cf2b7/cf2b7e80c327fa117a5f30fa9b6d95373a8885cf" alt=""