我想在一个长格式的数据集中,按组(这里的组是"国家"和"年份")计算各行的增长率.由于增长率应与"基准"情景下的相同值(即相同的"国家"和相同的"年份")相关(而不是与前一行相关),因此我将数据格式更改为宽格式,如下所示:
df <- spread(df, scenario, value) %>%
mutate(NDC_growth=((NDC/Baseline)-1)*100,
`Partial BCA_growth`=((`Partial BCA`/Baseline)-1)*100,
BCA_growth=((BCA/Baseline)-1)*100,
`Full BCA_growth`=((`Full BCA`/Baseline)-1)*100 )
有没有办法用长格式来做?
以下是数据:
df<- structure(list(country = c("CAN", "CAN", "CAN", "CAN", "CAN",
"CAN", "CAN", "CAN", "CAN", "CAN", "CAN", "CAN", "CAN", "CAN",
"CAN", "NCOA", "NCOA", "NCOA", "NCOA", "NCOA"), year = c("2020",
"2020", "2020", "2020", "2020", "2025", "2025", "2025", "2025",
"2025", "2030", "2030", "2030", "2030", "2030", "2020", "2020",
"2020", "2020", "2020"), scenario = c("Baseline", "BCA", "Full BCA",
"NDC", "Partial BCA", "Baseline", "BCA", "Full BCA", "NDC", "Partial BCA",
"Baseline", "BCA", "Full BCA", "NDC", "Partial BCA", "Baseline",
"BCA", "Full BCA", "NDC", "Partial BCA"), value = c(50527.8708215592,
50487.4619290311, 50485.0924261504, 50489.4453487844, 50486.1975947164,
55845.9708589775, 55070.2745559464, 55133.107605613, 55153.4525662034,
55065.0036253937, 61463.2383809614, 59893.8712077455, 59971.8726308887,
59936.72156767, 59875.7762254252, 338418.917408225, 338420.617142445,
338428.007621131, 338419.514027857, 338427.263672463)), row.names = c(NA,
-20L), class = c("tbl_df", "tbl", "data.frame"))