Monday, 22 April 2019

How to do an R style aggregate in Python Pandas?



I need to do an aggregate (at least that what you would call it in R) over the mtcars data set that I have uploaded into python. The end goal is to get the average mpg for each value of cyl in the data set (There are three values for cyl, 4,6,8). Here is the R code for what I want to do



mean_each_gear <- aggregate(mtcars$mpg ~ mtcars$cyl, FUN = mean)



output:

cyl mpg
1 4 26.66364
2 6 19.74286
3 8 15.10000



The closest I've come with in Pandas is this



mtcars.agg(['mean'])



I'm not sure how I would do that in Pandas. Any help would be appreciated!



Answer



You want pandas groupby()!



import pandas as pd

my_dataframe = pd.read_csv('my_input_data.csv') //insert your data here
pd.groupby(['col1'])['col2'].mean()


where 'col1' is the column you want to group by and 'col2' is the column whose mean you want to obtain. Also see here:




https://pandas.pydata.org/pandas-docs/stable/generated/pandas.DataFrame.groupby.html


No comments:

Post a Comment

php - file_get_contents shows unexpected output while reading a file

I want to output an inline jpg image as a base64 encoded string, however when I do this : $contents = file_get_contents($filename); print ...