我試圖將2列不等長的列表組合成一個數據框。r - 如何將列表中的多個列表組合成一個數據框
我從一個包含2個矩陣的列表開始。
mtx_a <- matrix(data = c(1:24), nrow = 4)
mtx_b <- matrix(data = c(25:36), nrow = 3)
row.names(mtx_a) <- c("A", "B", "C", "D")
row.names(mtx_b) <- c("A", "B", "C")
colnames(mtx_a) <- c("V1", "V2", "W1", "W2", "X1", "X2")
colnames(mtx_b) <- c("Y1", "Y2", "Z1", "Z2")
mtx_list <- list(mtx_a, mtx_b)
names(mtx_list) <- c("mtx_a", "mtx_b")
mtx_list
我已經提取了一個基於rowname的特定行來檢查。
mtx_list <- lapply(mtx_list, function(mtx_list){
mtx_list[row.names(mtx_list) %in% c("A"),]})
接下來我根據它們的索引提取了特定的列。 (交替列等同於條件1和2)。
cond_1 <- lapply(lapply(mtx_list, function(mtx_list) {
mtx_list[c(T,F)]}), unname)
cond_2 <- lapply(lapply(mtx_list, function(mtx_list) {
mtx_list[c(F,T)]}), unname)
我試圖產生看起來像這樣的一個數據幀:
cond_1 cond_2
mtx_a 1 5
mtx_a 9 13
mtx_a 17 21
mtx_b 25 28
mtx_b 31 34
我曾嘗試以下,但沒有取得任何結果:
list(cond_1, cond_2)
library(plyr)
ldply(c(cond_1, cond_2))