r - 通过 id 重塑并保持其他变量不变
问题描述
我想要做的是重新排序数据在列中的数据,但其余变量保持不变
c1<- c("ID","Location", "Year","Gender", "MoneySpent", "MoneyWithCreditCard")
c2<- c(1,"EEUU",2007,"M",1500,400)
c3<- c(1,"EEUU",2008,"M",3900,0)
c4<- c(1,"EEUU",2009,"M",0,100)
c5<- c(2,"Germany",2007,"F",0,1000)
c6<- c(2,"Germany",2008,"F",4000,500)
c7<- c(2,"Germany",2009,"F",700,0)
c8<- c(2,"Germany",2010,"F",0,50)
Df<-data.frame(rbind(c2,c3,c4,c5,c6,c7,c8))
colnames(Df)<-c1
# ID Location Year Gender MoneySpent MoneyWithCreditCard TypeofHome
#c2 1 EEUU 2007 M 1500 400 House
#c3 1 EEUU 2008 M 3900 0 House
#c4 1 EEUU 2009 M 0 100 House
#c5 2 Germany 2007 F 0 1000 Department
#c6 2 Germany 2008 F 4000 500 Department
#c7 2 Germany 2009 F 700 0 Department
#c8 2 Germany 2010 F 0 50 Department
我需要的结果是这个:
# ID Location Gender TypeofHome MS.2007 MS.2008 MS.2009 MS.2010 MWC.2007 MWC.2008 MWC.2009 MWC.2010
# 1 EEUU M House 1500 3900 0 NA 400 0 100 NA
# 2 Germany F Department 0 4000 700 0 1000 500 0 50
哪一个是更好的解决方案?谢谢顺便说一句!
解决方案
这将重命名原始数据中的列,因此只需要一个数据透视表:
library(dplyr)
library(tidyr)
Df %>%
rename(MS = MoneySpent, MWC = CreditCard) %>%
pivot_wider(names_from = c("Year"),
values_from = c("MS", "MWC"))
# # A tibble: 2 x 11
# ID Location Gender MS_2007 MS_2008 MS_2009 MS_2010 MWC_2007 MWC_2008 MWC_2009 MWC_2010
# <fct> <fct> <fct> <fct> <fct> <fct> <fct> <fct> <fct> <fct> <fct>
# 1 1 EEUU M 1500 3900 0 NA 400 0 100 NA
# 2 2 Germany F 0 4000 700 0 1000 500 0 50
推荐阅读
- angular - Angular7 - 通过 Bitbucket 包时生产构建失败
- sql-server - Numeric to datetime (yymmddhhmiss) in SQL Server
- javascript - Create a random sequence of non-recurring numbers between a 'min' and a 'max' number
- javascript - Javascript修改CSS时的CSS特异性?
- android - How to make checked button at BottomNavigationMenu?
- python-sphinx - How to create custom admonitions in custom directive sphinx?
- javascript - Socket.io only work sometimes and is sharing emit
- asp.net - DropDownList in MVC asp.net
- arrays - 如何将json数据中的复杂字符串转换为数组
- python-3.x - Selenium 的连接问题 - Python