Tenho um quadro de dados em R chamado data:
data
# A tibble: 192 × 4
Year Category Favor Percentage
<dbl> <chr> <chr> <dbl>
1 2002 A Good 35.8
2 2002 A Mediocre 31.9
3 2002 A Bad 45.3
4 2002 B Good 51.3
5 2002 B Mediocre 42.3
6 2002 B Bad 26.4
7 2002 C Good 64.4
8 2002 C Mediocre 33.4
9 2002 C Bad 24.2
10 2002 D Good 56.2
Quero girá-lo mais amplamente para que fique idealmente como o seguinte:
categoria | Ruim - 1998 | Ruim - 1999 | ... | Ruim - 2002 | Medíocre - 1998 | ... | Medíocre -2002 | Bom - 1998 ...Bom - 2002 |
---|---|---|---|---|---|---|---|---|
UM | ||||||||
B | ||||||||
C | ||||||||
E | ||||||||
E | ||||||||
F | ||||||||
G | ||||||||
E | ||||||||
EU | ||||||||
Eu | ||||||||
E | ||||||||
eu | ||||||||
M | ||||||||
Não | ||||||||
O | ||||||||
P |
ou seja, a coluna Categoria deve ser a primeira coluna e então começando da segunda Ruim e 1998, terceira coluna Ruim - 1999, quarta Ruim - 2001, quinta Ruim - 2002, sexta Medíocre - 1998, Medíocre - 1999, Medíocre - 2001, Medíocre - 2002, Bom - 1998, Bom - 1999, Bom - 2001 e finalmente a coluna Bom - 2002.
Como posso fazer isso em R usando funções do tidyverse?
Dados
dput(data)
structure(list(Year = c(2002, 2002, 2002, 2002, 2002, 2002, 2002,
2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002,
2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002,
2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002,
2002, 2002, 2002, 2002, 2002, 2002, 2002, 2002, 1998, 1998, 1998,
1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998,
1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998,
1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998,
1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998, 1998,
1998, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999,
1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999,
1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999,
1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999, 1999,
1999, 1999, 1999, 1999, 1999, 2001, 2001, 2001, 2001, 2001, 2001,
2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001,
2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001,
2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001,
2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001, 2001), Category = c("A",
"A", "A", "B", "B", "B", "C", "C", "C", "D", "D", "D", "E", "E",
"E", "F", "F", "F", "G", "G", "G", "H", "H", "H", "I", "I", "I",
"J", "J", "J", "K", "K", "K", "L", "L", "L", "M", "M", "M", "N",
"N", "N", "O", "O", "O", "P", "P", "P", "A", "A", "A", "B", "B",
"B", "C", "C", "C", "D", "D", "D", "E", "E", "E", "F", "F", "F",
"G", "G", "G", "H", "H", "H", "I", "I", "I", "J", "J", "J", "K",
"K", "K", "L", "L", "L", "M", "M", "M", "N", "N", "N", "O", "O",
"O", "P", "P", "P", "A", "A", "A", "B", "B", "B", "C", "C", "C",
"D", "D", "D", "E", "E", "E", "F", "F", "F", "G", "G", "G", "H",
"H", "H", "I", "I", "I", "J", "J", "J", "K", "K", "K", "L", "L",
"L", "M", "M", "M", "N", "N", "N", "O", "O", "O", "P", "P", "P",
"A", "A", "A", "B", "B", "B", "C", "C", "C", "D", "D", "D", "E",
"E", "E", "F", "F", "F", "G", "G", "G", "H", "H", "H", "I", "I",
"I", "J", "J", "J", "K", "K", "K", "L", "L", "L", "M", "M", "M",
"N", "N", "N", "O", "O", "O", "P", "P", "P"), Favor = c("Good",
"Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre",
"Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad",
"Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good",
"Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre",
"Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad",
"Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good",
"Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre",
"Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad",
"Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good",
"Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre",
"Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad",
"Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good",
"Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre",
"Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad",
"Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good",
"Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre",
"Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad",
"Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good",
"Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre",
"Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad",
"Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good",
"Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre",
"Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad",
"Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good",
"Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre",
"Bad", "Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad",
"Good", "Mediocre", "Bad", "Good", "Mediocre", "Bad", "Good",
"Mediocre", "Bad"), Percentage = c(36.85, 36.88, 46.28, 60.28,
45.3, 36.42, 70.44, 37.39, 34.17, 58.23, 48.77, 34.99, 67.53,
33.46, 32.01, 35.96, 35.33, 62.71, 46.84, 32.92, 42.24, 83.21,
26.67, 16.11, 65.91, 23.94, 46.15, 81.83, 23.86, 27.31, 74.32,
35.09, 33.59, 71.91, 30.92, 28.17, 62.84, 33.06, 27.1, 63.05,
44.81, 26.15, 76.68, 35.99, 23.33, 49.19, 34.58, 42.23, 55.21,
35.37, 34.42, 64.48, 36.53, 33.99, 70.81, 27.1, 31.09, 51.36,
43, 37.65, 64.57, 34.37, 29.06, 35.55, 28.44, 56.01, 56.84, 33.36,
38.8, 79.74, 35.74, 22.52, 66.86, 29.99, 44.15, 89.57, 27.79,
14.64, 82.49, 27.37, 27.14, 75.92, 33.39, 18.69, 69.8, 34.69,
29.51, 75.2, 42.63, 29.17, 90.33, 36.72, 13.95, 52.73, 30, 38.27,
68.14, 40.61, 33.25, 66.2, 33.99, 31.81, 80.38, 26.48, 21.13,
50.5, 40.36, 37.14, 74.17, 31.78, 29.04, 44.91, 35.24, 43.85,
69.23, 35.44, 32.33, 86.44, 24.11, 17.46, 69.69, 33.06, 40.25,
86.37, 21.21, 21.42, 80.11, 35.57, 32.32, 77.2, 32.03, 19.77,
72.98, 28.08, 20.94, 70.81, 29.12, 24.07, 88.14, 22.31, 16.55,
67.49, 44.16, 32.35, 69.03, 39.45, 28.52, 71.97, 37.6, 25.43,
79.06, 38.4, 19.55, 68.94, 37.03, 30.03, 80.74, 30.59, 30.67,
49.07, 45.79, 47.14, 60.1, 27.55, 34.36, 88.54, 30.2, 20.26,
59.42, 22.98, 43.61, 86.84, 16.73, 14.43, 77.42, 22.07, 22.52,
78.85, 23.88, 17.28, 78.22, 39.57, 27.22, 80.17, 26.21, 20.63,
94.63, 28.66, 13.71, 65.86, 31.97, 32.16)), row.names = c(NA,
-192L), class = c("tbl_df", "tbl", "data.frame"))
Provavelmente você pode tentar
o que dá