我正在合并一些存储在列表中的数据框。为此,我使用带有.df
命令的for循环。现在,我想在我的循环中的suffixes
中将数据框的名称用作paste
。
有没有办法,使用for ( .df in [list]) {
命令可以减去循环内.df
当前数据框的名称?
假设我有三个数据框的列表,
a <- list(A = data.frame(a=runif(2), b=runif(2)),
B = data.frame(a=runif(2), b=runif(2)),
C = data.frame(a=runif(2), b=runif(2)))
a
$A
a b
1 0.2833226 0.6242624
2 0.1741420 0.1707722
$B
a b
1 0.55073381 0.6082305
2 0.08678421 0.5192457
$C
a b
1 0.02788030 0.1392156
2 0.02171247 0.7189846
现在,我想使用这个循环,
for ( .df in a) {
print(['command I do not know about'])
}
然后让[我不知道的命令]打印出A,B,C(即.df
中数据框的名称)。
我能这样做吗?
这是使用上面的简单循环
剪切了我对输出的期望for ( .df in a) {
print(['command I do not know about'](a))
}
[1] "A"
[1] "B"
[1] "C"
我可以使用
获得此功能for (x in names(a)) {
print(x)
}
但是由于我正在做的事情的性质,我想在我的for循环中使用for ( .df in [list]) {
命令。
答案 0 :(得分:4)
要提取名称和值,您无法循环覆盖值。您可以遍历索引或名称:
# Loop over indices (faster, more cumbersome)
ns <- names(a)
for(i in seq_along(a)) {
v <- a[[i]] # extract value
n <- ns[[i]] # extract name
cat(n, ": \n")
str(v)
}
# Loop over names (easy but slower)
for(n in names(a)) {
v <- a[[n]] # extract value
cat(n, ": \n")
str(v)
}
...对于长向量,循环遍历名称和提取值可能非常慢(它具有n ^ 2时间复杂度)。
答案 1 :(得分:0)
不是for循环而是lapply但是类似于for循环。也许这会有所帮助,虽然我很困惑,因为我认为mrdwab的答案就是它。
FUN <-function(i){
x <- a[[i]]
data.frame(name=rep(names(a)[[i]], nrow(x)), x)
}
LIST <- lapply(seq_along(a), FUN)
do.call("rbind", LIST)
收率:
name a b
1 A 0.90139624 0.9739355
2 A 0.34311009 0.6621689
3 B 0.07585535 0.6010289
4 B 0.37292887 0.7260832
5 C 0.17814913 0.1433650
6 C 0.24586101 0.1741114