This question already has answers here:
Create empty dataframe in R with same columns

(3个答案)


6年前关闭。




我有一个数据框,我想从其中删除所有行,同时保留原始结构(列)。
 ddf
  vint1 vint2 vfac1 vfac2
1     9    10     1     3
2     9     6     3     4
3     6     2     2     2
4    10     6     2     4
5     7    12     3     2
>
>
>
> dput(ddf)
structure(list(vint1 = c(9L, 9L, 6L, 10L, 7L), vint2 = c(10L,
6L, 2L, 6L, 12L), vfac1 = structure(c(1L, 3L, 2L, 2L, 3L), .Label = c("1",
"2", "3"), class = "factor"), vfac2 = structure(c(2L, 3L, 1L,
3L, 1L), .Label = c("2", "3", "4"), class = "factor")), .Names = c("vint1",
"vint2", "vfac1", "vfac2"), class = "data.frame", row.names = c(NA,
-5L))

我试过了:
ddf = NA

for(i in 1:nrow(ddf) ddf[i,] = NULL

但它们不起作用。感谢您在这个基本问题上的帮助。

最佳答案

如果您确实要删除所有行:

> ddf <- ddf[0,]
> ddf
[1] vint1 vint2 vfac1 vfac2
<0 rows> (or 0-length row.names)

如果要使用占位符保留结构,则:
> ddf[,]=matrix(ncol=ncol(ddf), rep(NA, prod(dim(ddf))))
> ddf
  vint1 vint2 vfac1 vfac2
1    NA    NA    NA    NA
2    NA    NA    NA    NA
3    NA    NA    NA    NA
4    NA    NA    NA    NA
5    NA    NA    NA    NA

关于r - 如何从r中的data.frame中删除所有行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/25588336/

10-12 14:01