r - Average count per group -


i real close missing last step, tell me need change below?

my dataset (mydata) looks (the first few entries missing):

date_daily station_date air_min air_avg air_max rain_mm temp_davg_c temp_dmax_c temp_dmin_c       date months years 1 2006/01/01         <na>    <na>    <na>    <na>      na          na          na          na 2006-01-01     01  2006 2 2006/01/02         <na>    <na>    <na>    <na>      na          na          na          na 2006-01-02     01  2006 3 2006/01/03         <na>    <na>    <na>    <na>      na          na          na          na 2006-01-03     01  2006 4 2006/01/04         <na>    <na>    <na>    <na>      na          na          na          na 2006-01-04     01  2006 5 2006/01/05         <na>    <na>    <na>    <na>      na          na          na          na 2006-01-05     01  2006 6 2006/01/06         <na>    <na>    <na>    <na>      na          na          na          na 2006-01-06     01  2006 

the daily data ranges 2006 2016, interested in average monthly rain average days per month rain > 2mm.

so tried following:

library(dplyr) stats <- mydata %>% group_by(months) %>%   summarise(days_w_rain = length(rain_mm[!is.na(rain_mm)]),             avg_rain = mean(rain_mm, na.rm=true),             days_2mm = sum(rain_mm > 2, na.rm=true),             p2mm = days_2mm / days_w_rain*100) 

which gives me following:

# tibble: 12 x 5    months days_w_rain   avg_rain days_2mm      p2mm     <chr>       <int>      <dbl>    <int>     <dbl>  1     01         304 11.8078520      148 48.684211  2     02         310  7.4946903      125 40.322581  3     03         334  9.2680090      156 46.706587  4     04         327  3.7469113       92 28.134557  5     05         310  1.6073032       39 12.580645  6     06         300  1.1322100       39 13.000000  7     07         310  0.6212226       25  8.064516  8     08         333  1.6641862       47 14.114114  9     09         308  4.2796169       71 23.051948 10     10         310 10.7842742      155 50.000000 11     11         300 18.4062900      189 63.000000 12     12         287 20.6697038      155 54.006969 

this correct number average rain per month gives me total number of days in januaries have rain (i.e. 304 days), instead of average per month of january, same amount of days have >2mm of rain (i.e. 148 days on months of january 2006 2016. want average per month , not total).

i sure easy fix don't know how it? suggestions appreciated cheers sandra

assuming have data years (2006 2016) give desired output:

 stats <- mydata %>% group_by(months) %>%           summarise(days_w_rain = length(rain_mm[!is.na(rain_mm)]/length(unique(years))),                     avg_rain = mean(rain_mm, na.rm=true),                     days_2mm = sum(rain_mm > 2, na.rm=true)/length(unique(years)),                     p2mm = days_2mm / days_w_rain*100) 

this quick fix. dividing number of years , have average.


Comments

Popular posts from this blog

python Tkinter Capturing keyboard events save as one single string -

android - InAppBilling registering BroadcastReceiver in AndroidManifest -

javascript - Z-index in d3.js -