r - 如何使用 purrr::pmap 从数据框设置函数参数而不写所有的列名?

标签 r function purrr

我有这个数据框和函数。

df <- tibble(
  a = "a",
  b = "b",
  c = "c",
  d = "d",
  e = "e",
  f = "f",
  g = "g"
)

pmap(df, function(a, b, c, d, e, f, g) {
    
    var_1 <- paste0(a, b)

    var_2 <- c + d + e

    var_3 <- f/g

   tibble(
   a = var_1
   b = var_2
   c = var_3
)
    
  })

该函数按预期工作。由于列名可能超过七个,我不想在 function() 中写下所有列名。可以做什么?

所需的类似代码:

pmap(df, function(names(df)) {
  
    var_1 <- paste0(a, b)

    var_2 <- c + d + e

    var_3 <- f/g

   tibble(
   a = var_1
   b = var_2
   c = var_3
)
  
})

最佳答案

在这种情况下,我更喜欢 with(list(...), #stuff here )

基于 stefan 的工作解决方案:

pmap(df,~with(list(...),{var_1 <- paste0(a, b);
                        var_2 <- c + d + e;
                        var_3 <- f/g;
                        tibble(a = var_1, b = var_2, c = var_3)}))
#[[1]]
## A tibble: 1 × 3
#  a         b     c
#  <chr> <dbl> <dbl>
#1 ab        6   0.8

关于r - 如何使用 purrr::pmap 从数据框设置函数参数而不写所有的列名?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/73901497/

相关文章:

r - 计算 R 中每个组的凸包

r - R中的不均匀矩阵变换?

python - Tkinter : Issue with creating keyboard shortcuts

c++ - 我的电脑不接受 s.length,但其他编译器接受

r - 在带有 purrr map2 函数的线性模型中使用多个预测变量

r - 对象比相应的 .RData 文件大得多。为什么?你能手动做吗?

r - 如何仅删除一列中的 NA 数据?

Swift函数只能调用一次

r - 列名上的整洁评估映射

r - 在 mutate 中将参数传递给 pmap