如何删除R中Dataframe的第一级头?

问题描述 投票:1回答:1

我从聚合函数创建了一个数据框。数据帧的长度是两个。但是,当我打印出数据框时,会出现5列。 R如何处理数据框中的标题和子标题?如果是这种情况,我该如何摆脱第一级标题?

d <- data.frame("User id"=c(1,1,2,3,1),
                block=c("north","south","east","west","south"), check.names = F)

f <- function(l, vec) {
  vec[l] <- 1
  vec
}

vec <- setNames(rep(0, 4), levels(d$block))
df <- aggregate(block~`User id`, d, f, vec)

这些输出让我感到困惑:

>names(df)
[1] "User id" "block"



> df
  User id block.east block.north block.south block.west
1       1          0           1           1          0
2       2          1           0           0          0
3       3          0           0           0          1

这就是我想要的:

 > names(df)
 > "User id" "block.east" "block.north" "block.south" "block.west"
r dataframe header aggregate
1个回答
0
投票

我们可以使用table更轻松地完成这项工作

out <- as.data.frame.matrix(+(table(d) > 0))
names(df) <- paste0("block.", names(df))

关于OP输出中的问题,它是一个matrix专栏,

str(df)
#'data.frame':  3 obs. of  2 variables:
# $ User id: num  1 2 3
# $ block  : num [1:3, 1:4] 0 1 0 1 0 0 1 0 0 0 ...
#   ..- attr(*, "dimnames")=List of 2
#  .. ..$ : NULL
#  .. ..$ : chr  "east" "north" "south" "west"

所以我们可以转换为常规的data.frame

df <- do.call(data.frame, df)
names(df)
#[1] "User.id"     "block.east"  "block.north" "block.south" "block.west" 

str(df)
#'data.frame':  3 obs. of  5 variables:
# $ User.id    : num  1 2 3
# $ block.east : num  0 1 0
# $ block.north: num  1 0 0
# $ block.south: num  1 0 0
# $ block.west : num  0 0 1
© www.soinside.com 2019 - 2024. All rights reserved.