[英]R matrix to rownames colnames values
我有一個矩陣A,我想將其轉換為表格的data.frame:
rownames colnames values
運用
unlist(A)
幫助但不給我rownames
謝謝您的幫助。
你可以使用reshape2-package:
# load package
> require(reshape2)
# create an example matrix
> mdat <- matrix(c(1,2,3, 11,12,13), nrow = 2, ncol=3, byrow=TRUE,
+ dimnames = list(c("row1", "row2"),
+ c("C.1", "C.2", "C.3")))
> mdat
C.1 C.2 C.3
row1 1 2 3
row2 11 12 13
# bring matrix to long format using melt()
> melt(mdat)
Var1 Var2 value
1 row1 C.1 1
2 row2 C.1 11
3 row1 C.2 2
4 row2 C.2 12
5 row1 C.3 3
6 row2 C.3 13
基礎R的解決方案:
這是一個矩陣:
test <- matrix(1:9,nrow=3)
rownames(test) <- letters[1:3]
colnames(test) <- letters[4:6]
> test
d e f
a 1 4 7
b 2 5 8
c 3 6 9
根據需要轉換為data.frame
:
data.frame(
rownames=as.vector(row(test,as.factor=TRUE)),
colnames=as.vector(col(test,as.factor=TRUE)),
values=as.vector(test)
)
甚至更短,使用expand.grid
並確保命名輸入:
data.frame(
expand.grid(rownames=rownames(test),colnames=colnames(test)),
values=as.vector(test)
)
或者甚至更短,使用as.data.frame.table
(將提供大部分結果),並使用setNames
設置名稱
setNames(as.data.frame.table(test),c("rownames","colnames","values"))
結果:
rownames colnames values
1 a d 1
2 b d 2
3 c d 3
4 a e 4
5 b e 5
6 c e 6
7 a f 7
8 b f 8
9 c f 9
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.