- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想用 purrr 替代方案替换简单的 for 循环。我该如何编码并保持对象的原始结构
这是我的例子:
my_list <- list(
a = list(
list(
aaa = c(1:3),
aab = c(4:6),
aac = c(7:9)),
list(
aaa = c(10:12),
aab = c(13:15),
aac = c(16:18)),
list(
aaa = c(19:21),
aab = c(22:24),
aac = c(25:27))
))
和我原来的解决方案
x <- purrr::map_lgl(my_list$a, .f = ~ !is.null(.x$aaa))
my_list1 <- my_list
for (i in which(x)) {
my_list1$a[[i]]$aaa <- 99
}
str(my_list1)
但是,我也想用 purrr 解决方案替换我的 for 循环。我尝试过类似的方法,但 map 总是返回一个新列表而不是仅仅更新它
my_list2 <- map(c(1, 3),
function(x){
my_list[["a"]][[x]][["aab"]] <- 99
return(my_list)
}
)
str(my_list2)
Modify 应该更适用于这种情况,但我也无法让它发挥作用。
my_list3 <- purrr::map(
.x = which(x),
.f = function(i = .x) {
purrr::modify_in(.x = my_list,
.where = list("a", i, "aaa"),
.f = ~99)
}
)
str(my_list3)
新列表的结构应该与初始列表相同:
# str(my_list)
List of 1
$ a:List of 3
..$ :List of 3
.. ..$ aaa: int [1:3] 1 2 3
.. ..$ aab: int [1:3] 4 5 6
.. ..$ aac: int [1:3] 7 8 9
..$ :List of 2
.. ..$ aab: int [1:3] 13 14 15
.. ..$ aac: int [1:3] 16 17 18
..$ :List of 3
.. ..$ aaa: int [1:3] 19 20 21
.. ..$ aab: int [1:3] 22 23 24
.. ..$ aac: int [1:3] 25 26 27
# str(my_list1) is correct
List of 1
$ a:List of 3
..$ :List of 3
.. ..$ aaa: num 99
.. ..$ aab: int [1:3] 4 5 6
.. ..$ aac: int [1:3] 7 8 9
..$ :List of 2
.. ..$ aab: int [1:3] 13 14 15
.. ..$ aac: int [1:3] 16 17 18
..$ :List of 3
.. ..$ aaa: num 99
.. ..$ aab: int [1:3] 22 23 24
.. ..$ aac: int [1:3] 25 26 27
# str(my_list2) or str (my_list3) is not correct
List of 2
$ :List of 1
..$ a:List of 3
.. ..$ :List of 3
.. .. ..$ aaa: num 99
.. .. ..$ aab: int [1:3] 4 5 6
.. .. ..$ aac: int [1:3] 7 8 9
.. ..$ :List of 2
.. .. ..$ aab: int [1:3] 13 14 15
.. .. ..$ aac: int [1:3] 16 17 18
.. ..$ :List of 3
.. .. ..$ aaa: int [1:3] 19 20 21
.. .. ..$ aab: int [1:3] 22 23 24
.. .. ..$ aac: int [1:3] 25 26 27
$ :List of 1
..$ a:List of 3
.. ..$ :List of 3
.. .. ..$ aaa: int [1:3] 1 2 3
.. .. ..$ aab: int [1:3] 4 5 6
.. .. ..$ aac: int [1:3] 7 8 9
.. ..$ :List of 2
.. .. ..$ aab: int [1:3] 13 14 15
.. .. ..$ aac: int [1:3] 16 17 18
.. ..$ :List of 3
.. .. ..$ aaa: num 99
.. .. ..$ aab: int [1:3] 22 23 24
.. .. ..$ aac: int [1:3] 25 26 27
有什么提示我在使用 purrr 时出错了吗?
最佳答案
鉴于要修改的列表组件位于第二层嵌套,您也可以直接使用modify_depth
访问它们:
library(purrr)
my_list <- modify_depth(my_list, 2, ~list_modify(.x, aaa = 99))
str(my_list)
#> List of 1
#> $ a:List of 3
#> ..$ :List of 3
#> .. ..$ aaa: num 99
#> .. ..$ aab: int [1:3] 4 5 6
#> .. ..$ aac: int [1:3] 7 8 9
#> ..$ :List of 3
#> .. ..$ aaa: num 99
#> .. ..$ aab: int [1:3] 13 14 15
#> .. ..$ aac: int [1:3] 16 17 18
#> ..$ :List of 3
#> .. ..$ aaa: num 99
#> .. ..$ aab: int [1:3] 22 23 24
#> .. ..$ aac: int [1:3] 25 26 27
注意:这也适用于第一个列表级别的多个列表组件(例如 $a
、$b
...),而无需添加额外的迭代步骤。
编辑:如modify_depth
文档中所列:
modify_depth(x, 2, fun) is equivalent to x <- modify(x, ~ modify(., fun))
为了仅替换第二个嵌套级别上的部分列表组件,我们可以以更详细的方式重写对 modify_depth
的调用:
library(purrr)
## replace aaa only for components 1 and 3
modify_loc <- c(TRUE, FALSE, TRUE)
my_list <- modify(my_list, ~imodify(., ~if(modify_loc[.y]) list_modify(.x, aaa = 99) else .x))
str(my_list)
#> List of 1
#> $ a:List of 3
#> ..$ :List of 3
#> .. ..$ aaa: num 99
#> .. ..$ aab: int [1:3] 4 5 6
#> .. ..$ aac: int [1:3] 7 8 9
#> ..$ :List of 3
#> .. ..$ aaa: int [1:3] 10 11 12
#> .. ..$ aab: int [1:3] 13 14 15
#> .. ..$ aac: int [1:3] 16 17 18
#> ..$ :List of 3
#> .. ..$ aaa: num 99
#> .. ..$ aab: int [1:3] 22 23 24
#> .. ..$ aac: int [1:3] 25 26 27
关于r - 如何用 purrr 替换修改 for 循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57159153/
背景 我有一个问题,可能有多种解决方案,但我相信有一个尚未发现的优雅解决方案利用 purrr。 示例代码 我有一个如下的大数据框,为此我在下面提供了一个示例: library(tibble) libr
我正在尝试使用 purrr 的 modify_in 来修改列表的元素。列表示例: tib_list [[1]] #> # A tibble: 5 x 3 #> col_one col_two c
我正在努力了解 purrr,但我正在为一些本应很容易的事情而苦苦挣扎。 假设我有以下男性和女性数据 n 0, "M", "F")), value = rnorm(n) ) 现在,我要计算值列的以下
我想对“ID”以外的所有列应用 Blom 转换。由于它们都是数字,map_if 和 is.numeric 在这里不起作用。 library(rcompanion) data("mtcars") # G
考虑以下数据框列表: library(tidyverse) df1 % set_names(paste0("df", 1:4)) 如果不是这样,我想将 A 和 B 的元素连接到 B 列中。请注意,
我正在尝试使用 purrr对具有相同索引的列表元素求和。这可以使用以下方法在基础 R 中实现: xx % reduce(sum)返回单个值。有谁知道在 purrr 中执行此操作的语法吗? ? 编辑-我
我有类似于df3的数据。要重现数据,请运行以下命令: vec1 % group_by(A) %>% nest() df2 % left_join(df2, by = "A") 我需要使用这样的
我搜索了 ??"~"但这只能指向 rlang::env_bind (大概是 %<~% )和 base::~ .在 RStudio 中,如何找到 Purrr 的 ~的文档?例如,如果我忘记了如何使用 ~
这个问题在这里已经有了答案: Repeat each row of data.frame the number of times specified in a column (9 个回答) 10 个月
我有以下数据框列表,其中包含名为 cyl 的列 # Create 3 dataframes with identical column names mt_list [[1]] #>
我正在查看使用map的example。这里是: mtcars %>% split(.$cyl) %>% # from base R map(~ lm(mpg ~ wt, data = .))
我没有看到任何关于我的问题。我想,当我看到 purrr 很多模型示例时,如何再次使用在数据上创建的模型?一点点代码会告诉你我在追求什么: 这是基本的gapminder许多模型示例。 library(g
这是一个嵌套数据。 df1 % group_by(group) %>% nest() 我需要使用 purrr:map 运行 lm。 map(df2$data, ~lm(A~B, data=.x)) 找
我有一个命名列表,在该列表中我想根据列表的来源名称重命名它们的列。 我的方法的问题似乎是 .x 占位符,我认为它是我唯一的列表名称。但在 rename_with 函数中,.x 似乎是在每个列表数据框中
给定一个 dataframe,比如 iris 默认值,如何配置 purrr::map_dfr() 函数在 的每一行上运行code>dataframe 并执行函数 foo。 这是我的 df 的一行,请注
感谢这个网站,我使用 R purrr 包来聚合基于多列的数据。聚合按我想要的方式工作,但输出却不然。以下是使用 mtcars 数据集的示例。 library(dplyr) library(purrr)
这是一个嵌套数据。 df1 % group_by(group) %>% nest() 我需要使用 purrr:map 运行 lm。 map(df2$data, ~lm(A~B, data=.x)) 找
我有一个命名列表,在该列表中我想根据列表的来源名称重命名它们的列。 我的方法的问题似乎是 .x 占位符,我认为它是我唯一的列表名称。但在 rename_with 函数中,.x 似乎是在每个列表数据框中
给定一个 dataframe,比如 iris 默认值,如何配置 purrr::map_dfr() 函数在 的每一行上运行code>dataframe 并执行函数 foo。 这是我的 df 的一行,请注
也许我遗漏了一些明显的东西,但我试图将 R 中命名列表的命名列表(甚至可能更多嵌套)扁平化为最终一个扁平列表。 purrr和 rlist似乎有工具。我怎样才能实现子列表的名称成为扁平结果列表的名称预加
我是一名优秀的程序员,十分优秀!