gpt4 book ai didi

r - 对 data.frames 列表进行子集并返回 data.frames 列表

转载 作者:行者123 更新时间:2023-12-04 11:17:41 25 4
gpt4 key购买 nike

我意识到这个问题与 this one 非常相似(除其他外)但是我似乎无法修改解决方案以适应我的问题。如果需要,请标记为重复或链接到现有答案。以下是从上述问题稍微修改的一些示例数据:

a=c(1,2,3,4,5,6)
b=c(4,5,6,5,5,5)
c=c(3,4,5,6,7,8)
A=data.frame(a=a,b=b,c=c)
B=data.frame(a=c,b=b,c=a)
C=data.frame(a=b,b=c,c=a)
l <- list(A, B, C)

我想生成一个数据帧列表,它是与条件匹配的原始数据帧(在 l 中)的子集。例如,我可能想返回所有大于或等于 4 的值,并将较低的值替换为 NA这样我的新列表, subsetl看起来如下。 (我不在乎将 NA 保留在数据框中的正确位置。)
> subsetl
[[1]]
a b c
1 NA 4 NA
2 NA 5 4
3 NA 6 5
4 4 5 6
5 5 5 7
6 6 5 8

[[2]]
a b c
1 NA 4 NA
2 4 5 NA
3 5 6 NA
4 6 5 4
5 7 5 5
6 8 5 6

[[3]]
a b c
1 4 NA NA
2 5 4 NA
6 5 NA
4 5 6 4
5 5 7 5
6 5 8 6

我希望我的例子足够清楚,可以理解,但如果没有,请告诉我。这无疑是简单的使用 lapply , sapply或类似的,但在使用列表时我无法正确使用语法,尤其是当数据框列表是所需的结果时。

最佳答案

这应该为你做:

subsetl <- lapply(l,function(x) {
x[x<4] <- NA
return(x)
})

结果:
>subsetl
[[1]]
a b c
1 NA 4 NA
2 NA 5 4
3 NA 6 5
4 4 5 6
5 5 5 7
6 6 5 8

[[2]]
a b c
1 NA 4 NA
2 4 5 NA
3 5 6 NA
4 6 5 4
5 7 5 5
6 8 5 6

[[3]]
a b c
1 4 NA NA
2 5 4 NA
3 6 5 NA
4 5 6 4
5 5 7 5
6 5 8 6

关于r - 对 data.frames 列表进行子集并返回 data.frames 列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17946132/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com