在dplyr中使用mutate_all格式化所有列

Kon*_*rad 6 string formatting r dplyr

我正在寻找使用内部格式化表格.scales::dollar mutate_all

期望的结果

使用以下方法可以获得所需的结果sapply:

>> sapply(mtcars, scales::dollar)
      mpg      cyl  disp      hp     drat    wt      qsec     vs   am   gear carb
 [1,] "$21.00" "$6" "$160.00" "$110" "$3.90" "$2.62" "$16.46" "$0" "$1" "$4" "$4"
 [2,] "$21.00" "$6" "$160.00" "$110" "$3.90" "$2.88" "$17.02" "$0" "$1" "$4" "$4"
 [3,] "$22.80" "$4" "$108.00" "$93"  "$3.85" "$2.32" "$18.61" "$1" "$1" "$4" "$1"
 [4,] "$21.40" "$6" "$258.00" "$110" "$3.08" "$3.22" "$19.44" "$1" "$0" "$3" "$1"
Run Code Online (Sandbox Code Playgroud)

挑战

试图通过实现相同的结果dplyr管道 scales::dollar:

mtcars %>% mutate_all(funs(scales::dollar(.)))
Run Code Online (Sandbox Code Playgroud)

失败:

Error in vapply(dots[missing_names], function(x) make_name(x$expr), character(1)) : 
  values must be length 1,
 but FUN(X[[1]]) result is length 3
Run Code Online (Sandbox Code Playgroud)

进一步探索

可以尝试原始的解决方法:

mtcars %>% mutate_each(funs(as.character(paste0("$", .))))
Run Code Online (Sandbox Code Playgroud)

结果:

>> mtcars %>% mutate_each(funs(as.character(paste0("$", .))))
     mpg cyl   disp   hp  drat     wt   qsec vs am gear carb
1    $21  $6   $160 $110  $3.9  $2.62 $16.46 $0 $1   $4   $4
2    $21  $6   $160 $110  $3.9 $2.875 $17.02 $0 $1   $4   $4
3  $22.8  $4   $108  $93 $3.85  $2.32 $18.61 $1 $1   $4   $1
Run Code Online (Sandbox Code Playgroud)

经过类似的讨论后,可以很容易地进一步开发这种方法来创建所需的货币格式,但这不是重点.

  • scales::dollar(.)mutate_all(或mutate_each)内部应用时为什么失败?当应用于向量元素时,它按预期工作,不应该在mutate_all/中传递时沿着列中可用的观察值复制此行为mutate_each:

    >> scales::dollar(c(1, 1e4)) 
    [1] "$1"      "$10,000"
    
    Run Code Online (Sandbox Code Playgroud)

akr*_*run 4

我们需要as.character用 with 换行,因为当我们package::functionfuns. 它记录在这里

mtcars %>% 
     mutate_each(funs(as.character(scales::dollar(.))))
Run Code Online (Sandbox Code Playgroud)

mutate_each此外,根据 @Frank 共享的博客链接,该函数已被弃用,因此我们可以使用mutate_at

mtcars %>% 
       mutate_at(names(.), funs(as.character(scales::dollar(.))))
Run Code Online (Sandbox Code Playgroud)

补救措施是加载包,然后调用而不使用::

library(scales)
mtcars %>% 
    mutate_at(names(.), funs(dollar(.)))
Run Code Online (Sandbox Code Playgroud)

或者

mtcars %>% 
        mutate_at(names(.), dollar)
Run Code Online (Sandbox Code Playgroud)