枢轴更长 - 提取列名的一部分
我想旋转更长的时间。我希望旋转的每个列名都有相同的开始; “ e_mort”,因此可以忽略,但理想情况下,我希望在新列名的开始时保留。每个列名的末尾是可变的,但始终为可变长度字符和/或数字字符串的格式,例如'num'或“ 100k”,或者随后是下划线和另一个字符字符串(无数值)EG' num_lo'或'100k_lo'。我希望提取的信息和枢轴是列名称的中心部分,它始终是'exc_tbhiv'或'tbhiv'。
数据集看起来像这样:
year <- c(2000, 2000, 2001, 2001, 2002, 2002)
location <- rep(c("global","SA"), 3)
e_mort_exc_tbhiv_num <- c(1698959, 26000, 1693829, 27000, 1687579, 29000)
e_mort_exc_tbhiv_num_lo <- c(1600000, 25000, 1600000, 26000, 1600000, 28000)
e_mort_tbhiv_num <- c(674398, 116000, 652384, 144000, 616975, 136000)
e_mort_tbhiv_num_lo <- c(535000, 65000, 517000, 79000, 486000, 75000)
data <- tibble(year,location,
e_mort_exc_tbhiv_num,
e_mort_exc_tbhiv_num_lo,
e_mort_tbhiv_num,
e_mort_tbhiv_num_lo)
data
所需的输出是:
A tibble: 12 x 5
year location group e_mort_num e_mort_num_lo
<dbl> <chr> <chr> <dbl> <dbl>
1 2000 global exc_tbhiv 1698959 1600000
2 2000 global tbhiv 674398 535000
3 2000 SA exc_tbhiv 26000 25000
4 2000 SA tbhiv 116000 65000
5 2001 global exc_tbhiv 1693829 1600000
6 2001 global tbhiv 652384 517000
7 2001 SA exc_tbhiv 27000 26000
8 2001 SA tbhiv 144000 79000
9 2002 global exc_tbhiv 1687579 1600000
10 2002 global tbhiv 616975 486000
11 2002 SA exc_tbhiv 29000 28000
12 2002 SA tbhiv 136000 75000
谢谢
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
我们可以通过重新安排子字符串重命名列,然后使用
pivot_longer
output
We could rename the columns by rearranging the substring and then use
pivot_longer
-output
单个
pivot_longer
呼叫:在2022-05-29上创建的另一个选项,由(v2.0.1)
Another option with a single
pivot_longer
call:Created on 2022-05-29 by the reprex package (v2.0.1)