我有以下问题:在csv文件中,我有一个物种列,一个用于横断面,一个用于年份,一个用于AUC。在另一个csv文件中,我有一个横断面列,一个用于年份,一个用于降水,一个用于温度。现在我想以某种方式加入R中的文件,我可以从第二个csv获得物种和AUC的列,从第一个csv获得其余的列。 最后,我想得到一个包含transect_id,年,日,月,物种,regional_gam(= AUC),降水和LST(=温度)的文件。 因此,基本上2008年每天TR001的降水/ LST值需要分配给具有2008年和TR001的AUC值的每个物种。 谢谢!
答案 0 :(得分:2)
使用read.csv
然后merge
。
将两个csv文件加载到R中。(不要忘记确保它们的公共变量共享相同的名称!)。
df1<-read.csv(dat1,head=T)
df2<-read.csv(dat2,head=T)
通过共享变量将数据帧合并在一起并添加参数all.x = T(默认值)以确保所有行都保留在包含物种的数据库中。
merge(df1,df2,by=c('transect_id','year'),all.x=T)
要使用测试数据查看此操作:
test<-data.frame(sp=c(rep(letters[1:10],2)),t=c(rep(1:3,2,20)),y=c(rep(2000:2008,len=20)),AUC=1:20)
test2<-data.frame(t=c(rep(1:3,2,9)),y=c(rep(2000:2008,len=9)),ppt=c(1:9),temp=c(11:19))
merge(test,test2,by=c('t','y'),all.x=T)
答案 1 :(得分:0)
请使用
library(dplyr)
df1<- read.csv("F:\\Test_Anything\\Merge\\1.csv" , head(T))
df2<-read.csv("F:\\Test_Anything\\Merge\\2.csv" , head(T))
r <- merge(df1,df2,by=c('NAME','NAME'),all.x=T)
write.csv(r,"F:\\Test_Anything\\Merge\\DF.csv" , all(T) )