我查询了数据表和数据框中的cbind特性。 如果我绑定数据帧(df)和数据表(dt),则结果对象的类取决于第一个参数。
示例:
> dt<-data.table(x=c(1,2,3),y=c(2,3,4),z=c(3,4,5))
> df<-data.frame(x=c(1,2,3),y=c(2,3,4),z=c(3,4,5))
> dt
x y z
1: 1 2 3
2: 2 3 4
3: 3 4 5
案例1 :(第一个参数作为数据框)
>test_df<-cbind(df,dt)
>class(test_df)
[1] "data.frame"
案例2 :(第一个参数作为数据表)
>test_dt<-cbind(dt,df)
>class(test_dt)
[1] "data.table" "data.frame"
所以,我的问题是如何在两种不同的情况下将输出对象作为数据表和数据框来获取,其中cbind没有data.table方法。
在合并函数中很明显,R根据第一个参数调用不同的合并函数(如果第一个参数是它调用的数据帧,数据帧,如果是数据表,则调用数据表合并方法)。
对任何语法错误道歉,如果这是一个重复的问题,请告诉我。
感谢。
答案 0 :(得分:3)
如果您查看cbind.data.frame
的代码,就会看到有data.table
案例的检查:
cbind.data.frame
# function (..., deparse.level = 1)
# {
# if (!identical(class(..1), "data.frame"))
# for (x in list(...)) {
# if (inherits(x, "data.table"))
# return(data.table::data.table(...))
# }
# data.frame(..., check.names = FALSE)
# }
# <environment: namespace:base>
相当奇怪,我同意 - 我本来期望一种cbind.data.table
方法,但我想有一些很好的理由不这样做。