使用 R 中数据框列表中的数据框名称附加一个新列
Append a new column using the name of dataframe from list of dataframe in R
给定数据帧列表l
如下:
l <- list(a = data.frame(a_1 = c(11, 12),
a_2 = c(13, 14)),
b = data.frame(b_1 = c(21, 22),
b_2 = c(23, 24)),
c = data.frame(c_1 = c(31, 32),
c_2 = c(33, 34)))
print(l)
输出:
现在我想使用每个数据框的名称附加一个新列 new_col
:
l[['a']]$new_col = 'a'
l[['b']]$new_col = 'b'
l[['c']]$new_col = 'c'
我想知道如何使用自动为 [1] "a" "b" "c"
的 names(l)
为每个数据框附加列?谢谢。
最后的结果是这样的:
方法 1:使用 map2 的 tidyverse 解决方案
library(tidyverse)
map2(l, names(l), ~ mutate(.x, new_col = .y))
输出:
$a
a_1 a_2 new_col
1 11 13 a
2 12 14 a
$b
b_1 b_2 new_col
1 21 23 b
2 22 24 b
$c
c_1 c_2 new_col
1 31 33 c
2 32 34 c
方法二:for循环解决
(l
给出以上输出):
for(i in 1:length(names(l))) {
l[[i]]$new_col <- names(l)[i]
}
或 mapply()
:
mapply(cbind, l, "new_col"=names(l), SIMPLIFY=F)
给定数据帧列表l
如下:
l <- list(a = data.frame(a_1 = c(11, 12),
a_2 = c(13, 14)),
b = data.frame(b_1 = c(21, 22),
b_2 = c(23, 24)),
c = data.frame(c_1 = c(31, 32),
c_2 = c(33, 34)))
print(l)
输出:
现在我想使用每个数据框的名称附加一个新列 new_col
:
l[['a']]$new_col = 'a'
l[['b']]$new_col = 'b'
l[['c']]$new_col = 'c'
我想知道如何使用自动为 [1] "a" "b" "c"
的 names(l)
为每个数据框附加列?谢谢。
最后的结果是这样的:
方法 1:使用 map2 的 tidyverse 解决方案
library(tidyverse)
map2(l, names(l), ~ mutate(.x, new_col = .y))
输出:
$a
a_1 a_2 new_col
1 11 13 a
2 12 14 a
$b
b_1 b_2 new_col
1 21 23 b
2 22 24 b
$c
c_1 c_2 new_col
1 31 33 c
2 32 34 c
方法二:for循环解决
(l
给出以上输出):
for(i in 1:length(names(l))) {
l[[i]]$new_col <- names(l)[i]
}
或 mapply()
:
mapply(cbind, l, "new_col"=names(l), SIMPLIFY=F)