我有一个宽格式的数据框,如下所示。 我想使用data.table的melt函数将宽格式转换为长格式。在简单的情况下,我可以将两个数据拆分,然后将两个数据集合并。 但在我的情况下,有多个test(i)testgr(i)列。但一定有更好和更有效的方法来做到这一点。谢谢。
to =>
我有一个宽格式的数据框,如下所示。我想使用data.table的melt函数将其转换为长格式。在简单的情况下,我可以拆分两个数据,然后将两个数据集合并。但在我的情况下,存在多个test(i)testgr(i)列。不过可能有更好和更有效的方法。谢谢。
id<-c("106E1258","106E2037","104E1182","105E1248","105E1470","10241247",
"10241703")
yr<-c(2017,2017,2015,2016,2016,2013,2013)
finalgr<-c(72,76,75,71,75,77,78)
test01<-c("R0560","R0066","R0308","R0129","R0354","R0483",
"R0503")
test01gr<-c(73,74,67,80,64,80,70)
test02<-c("R0660","R0266","R0302","R0139","R0324","R0383" ,
"R0503")
test02gr<-c(71,54,67,70,68,81,61)
dt<-data.frame(id=id,yr=yr,
finalgr=finalgr,
test01=test01,test01gr=test01gr,
test02=test02,test02gr=test02gr)
(这是一个无法独立翻译的代码片段,需要更多上下文才能确定其最终意义和用途)id2<-c("106E1258","106E1258","104E1182","104E1182")
yr2<-c(2017,2017,2015,2015)
finalgr<-c(72,72,75,75)
testid<-c("R0560","R0660","R0308","R0302")
testgr<-c(73,71,67,67)
dt2<-data.frame(id=id2,yr=yr2,finalgr=finalgr,testid=testid,testgr=testgr)
data.frame
命名为"dt"
可能是一个好主意,因为大多数人都使用它作为data.table
的示例名称。 - Mike H.