I want annual data from monthly data (sum of every 12 months)

2 visualizaciones (últimos 30 días)
BN
BN el 30 de Mzo. de 2020
Editada: Peng Li el 30 de Mzo. de 2020
Hey all,
I have a 1 x3 cell which contains 3 tables (360x3). In each table, there is a "dates" column (MM/DD/YYYY) and precipitation value (rrr24) column. The dates are for 30 years, monthly. Please help me to have another 1 x3 cell (newcell) which contains 30x3 tables with the amount of precipitation for each year instead of the month. I would like to use the sum function to convert monthly precipitation to annual.
I attached my cell.
Thank you so much.

Respuesta aceptada

Peng Li
Peng Li el 30 de Mzo. de 2020
Hi, you again lol and me again
I thought it would be easier for you to solve this with my previous answer regarding the season stuff.
newCell = cellfun(@cusFun, CELL, 'UniformOutput', 0);
function cusTbl = cusFun(tbl)
tbl.year = year(tbl.dates);
[grp, cusTbl] = findgroups(tbl(:, 'year'));
cusTbl.sum_rrr24 = splitapply(@sum, tbl.rrr24, grp);
cusTbl.grid_name = splitapply(@(x) x(1), tbl.(1), grp);
end
  2 comentarios
BN
BN el 30 de Mzo. de 2020
Dear Peng Li
Thank you so much. I never forget your precious help at this moment that my university is closed and quarantine restricts my contact ways.
Be healthy
Best regards?
Peng Li
Peng Li el 30 de Mzo. de 2020
Editada: Peng Li el 30 de Mzo. de 2020
Thanks Behzad Navidi. Stay safe!
I'm working from home too because of the virus.

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Entering Commands en Help Center y File Exchange.

Etiquetas

Productos


Versión

R2018b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by