> dput(test)
structure(list(MEMORY1 = c(7.5, 6, 6, 3.5, 5, 5), MEMORY2 = c(5,
7.5, 3, 3.5, 5, 5), MEMORY3 = c(5, 3.5, 3, 3.5, 5, 2), MEMORY4 = c(2,
1.5, 3, 3.5, 1, 2), MEMORY5 = c(7.5, 3.5, 3, 3.5, 5, 7), MEMORY6 = c(2,
5, 7.5, 7.5, 5, 5), MEMORY7 = c(2, 1.5, 3, 3.5, 5, 2), MEMORY8 = c(5,
7.5, 7.5, 7.5, 5, 8)), .Names = c("MEMORY1", "MEMORY2", "MEMORY3",
"MEMORY4", "MEMORY5", "MEMORY6", "MEMORY7", "MEMORY8"), row.names = c(NA,
6L), class = "data.frame")
> test
MEMORY1 MEMORY2 MEMORY3 MEMORY4 MEMORY5 MEMORY6 MEMORY7 MEMORY8
1 7.5 5.0 5.0 2.0 7.5 2.0 2.0 5.0
2 6.0 7.5 3.5 1.5 3.5 5.0 1.5 7.5
3 6.0 3.0 3.0 3.0 3.0 7.5 3.0 7.5
4 3.5 3.5 3.5 3.5 3.5 7.5 3.5 7.5
5 5.0 5.0 5.0 1.0 5.0 5.0 5.0 5.0
6 5.0 5.0 2.0 2.0 7.0 5.0 2.0 8.0
Run Code Online (Sandbox Code Playgroud)
我有一个data.frame,我想只是第一行的子集.如果我这样做test[1, ],结果是
> test[1, ]
MEMORY1 MEMORY2 MEMORY3 MEMORY4 MEMORY5 MEMORY6 MEMORY7 MEMORY8
1 7.5 5 5 2 7.5 2 2 5
Run Code Online (Sandbox Code Playgroud)
我如何对data.frame进行子集化,这样我只得到一个没有列名的数字向量?
use*_*691 11
你想要的是一个数字向量而不是data.frame.为此,您可以使用as.numeric进行转换
> as.numeric(df[1,])
[1] 7.5 5.0 5.0 2.0 7.5 2.0 2.0 5.0
Run Code Online (Sandbox Code Playgroud)
您可以使用unlistwith选项use.names=FALSE仅返回vector没有名称.
unlist(test[1,], use.names=FALSE)
#[1] 7.5 5.0 5.0 2.0 7.5 2.0 2.0 5.0
Run Code Online (Sandbox Code Playgroud)
test[1,]仍然是data.frame8列.A data.frame可以被视为list具有相同length的list元素(或列).所以我们可以使用unlist.当您vector从多行创建时,这也适用.
unlist(test[1:2,], use.names=FALSE)
Run Code Online (Sandbox Code Playgroud)
或者正如@Frank建议的那样,如果我们通过保持维度来对多行进行子集化,我们将名称设置为NULL并转换为matrix.
as.matrix(setNames(test[1:2,],NULL))
Run Code Online (Sandbox Code Playgroud)