Reformar datos de formato largo a ancho: más de una variable [duplicado]
Esta pregunta ya tiene una respuesta aquí:
Reformar múltiples valores a la vez 2 respuestasEstoy tratando de cambiar la forma de mis datos de fórmula larga a amplia usando eldcast
funcionar desdereshape2.
El objetivo es utilizar diferentes variables en elvalue.var
parámetro pero R no me deja usar más de un valor en él.
¿Hay alguna otra forma de solucionarlo? He examinado otras preguntas similares, pero no he podido encontrar ejemplos similares.
Aquí está mi conjunto de datos actual:
+---------+------+--------+--------------+------------+
| Country | Year | Growth | Unemployment | Population |
+---------+------+--------+--------------+------------+
| A | 2015 | 2 | 8.3 | 40 |
| B | 2015 | 3 | 9.2 | 32 |
| C | 2015 | 2.5 | 9.1 | 30 |
| D | 2015 | 1.5 | 6.1 | 27 |
| A | 2016 | 4 | 8.1 | 42 |
| B | 2016 | 3.5 | 9 | 32.5 |
| C | 2016 | 3.7 | 9 | 31 |
| D | 2016 | 3.1 | 5.3 | 29 |
| A | 2017 | 4.5 | 8.1 | 42.5 |
| B | 2017 | 4.4 | 8.4 | 33 |
| C | 2017 | 4.3 | 8.5 | 30 |
| D | 2017 | 4.2 | 5.2 | 30 |
+---------+------+--------+--------------+------------+
Mi objetivo es pasar la columna del año al resto de las columnas (crecimiento, desempleo y población). Estoy usando la siguiente función dcast.
data_wide <- dcast(world, country ~ year,
value.var=c("Growth","Unemployment","Population"))
Resultado ideal
+---------+-------------+-------------------+-----------------+-------------+-------------------+-----------------+
| Country | Growth_2015 | Unemployment_2015 | Population_2015 | Growth_2016 | Unemployment_2016 | Population_2016 |
+---------+-------------+-------------------+-----------------+-------------+-------------------+-----------------+
| A | 2 | 8.3 | 40 | 4 | 8.1 | 42 |
| B | 3 | 9.2 | 32 | 3.5 | 9 | 32.5 |
| C | 2.5 | 9.1 | 30 | 3.7 | 9 | 31 |
| D | 1.5 | 6.1 | 27 | 3.1 | 5.3 | 29 |
+---------+-------------+-------------------+-----------------+-------------+-------------------+-----------------+