我试图初始化一个data。frame,没有任何行。基本上,我希望为每个列指定数据类型并命名它们,但结果不创建任何行。

到目前为止,我能做的最好的事情是:

df <- data.frame(Date=as.Date("01/01/2000", format="%m/%d/%Y"), 
                 File="", User="", stringsAsFactors=FALSE)
df <- df[-1,]

它创建了一个data.frame,包含我想要的所有数据类型和列名的单行,但也创建了一个无用的行,然后需要删除。

还有更好的办法吗?


当前回答

如果你不介意不显式地指定数据类型,你可以这样做:

headers<-c("Date","File","User")
df <- as.data.frame(matrix(,ncol=3,nrow=0))
names(df)<-headers

#then bind incoming data frame with col types to set data types
df<-rbind(df, new_df)

其他回答

如果你在寻找短:

read.csv(text="col1,col2")

因此不需要单独指定列名。在填充数据帧之前,您将获得默认的逻辑列类型。

你可以用read。表中输入的文本为空字符串,如下所示:

colClasses = c("Date", "character", "character")
col.names = c("Date", "File", "User")

df <- read.table(text = "",
                 colClasses = colClasses,
                 col.names = col.names)

或者将col.names指定为字符串:

df <- read.csv(text="Date,File,User", colClasses = colClasses)

感谢Richard Scriven的改进

如果你不介意不显式地指定数据类型,你可以这样做:

headers<-c("Date","File","User")
df <- as.data.frame(matrix(,ncol=3,nrow=0))
names(df)<-headers

#then bind incoming data frame with col types to set data types
df<-rbind(df, new_df)

假设您的列名是动态的,您可以创建一个空的以行命名的矩阵并将其转换为数据帧。

nms <- sample(LETTERS,sample(1:10))
as.data.frame(t(matrix(nrow=length(nms),ncol=0,dimnames=list(nms))))

如果你已经有一个存在的数据帧,比如df,它有你想要的列,那么你可以通过删除所有的行来创建一个空的数据帧:

empty_df = df[FALSE,]

注意df仍然包含数据,但empty_df没有。

我发现这个问题是寻找如何创建一个空行的新实例,所以我认为它可能对一些人有帮助。