Tengo un problema al hacer la estructura de los datos.

enter image description here

lv1<-c(5,2,8)
lv2<-c(9,3,6)
lv3<-c(5,0,2)
df<-data.frame(lv1,lv2,lv3)

El resultado de los datos es el número de personas bajo lv1, lv2 y lv3. pero quiero investigar la relación entre el número de personas y diferentes niveles de nivel, por lo que me gustaría convertirlo con este aspecto:

enter image description here

lv<- c('lv1','lv1','lv1','lv2','lv2','lv2','lv3','lv3','lv3')
number.of.people<-(c(5,2,8,9,3,6,5,0,2))
new.df<-data.frame(lv,number.of.people)

¿Hay algún código que pueda hacer eso?

1
Zhenpeng Hu 16 oct. 2018 a las 17:03

2 respuestas

La mejor respuesta

Esto no usa paquetes.

long <- stack(df)

Dando:

> long
  values ind
1      5 lv1
2      2 lv1
3      8 lv1
4      9 lv2
5      3 lv2
6      6 lv2
7      5 lv3
8      0 lv3
9      2 lv3

Si desea cambiar los nombres e invertir el orden de las columnas, entonces:

long <- stack(df)[2:1]
names(long) <- c("lv", "no.of.people")
0
G. Grothendieck 16 oct. 2018 a las 14:41

Necesitas tidyverse:

library(tidyverse)
    new.df%>%
     gather(lv,number.of.people)
   lv number.of.people
1 lv1                5
2 lv1                2
3 lv1                8
4 lv2                9
5 lv2                3
6 lv2                6
7 lv3                5
8 lv3                0
9 lv3                2
2
jyjek 16 oct. 2018 a las 14:17