AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / Perguntas / 79424061
Accepted
Jaken
Jaken
Asked: 2025-02-09 07:12:27 +0800 CST2025-02-09 07:12:27 +0800 CST 2025-02-09 07:12:27 +0800 CST

Passando uma coluna de quadro de dados opcional para uma função personalizada

  • 772

Tenho uma função personalizada que recebe como entrada um quadro de dados e, em seguida, uma seleção de colunas desse quadro de dados, assim:

library(dplyr)
df <- data.frame(x = c(1, 2, 3, 4, 5), y = c(11, 12, 13, 14, 15))

sample_fun <- function(df, x, y) {
  df <- df %>% 
    mutate(z = {{x}} * {{y}})
  }

df_out <- sample_fun(df, x, y)

Gostaria de tornar uma das colunas do data frame opcional e, então, fazer a função testar sua presença usando !if.null(). Se isso fosse um objeto, em vez de uma coluna do data frame, eu faria isso:

sample_fun <- function(df, x, y = NULL) {
  if(!is.null(y)) {
    df <- df %>% 
      mutate(z = {{x}} * y)
  }
  else(df <- df %>%
         mutate(z = {{x}}))
}

df_out <- sample_fun(df, x) 
df_out2 <- sample_fun(df, x, y)

No entanto, não consigo descobrir como verificar a presença da coluna de dados. Ambos if(!is.null(y))e if(!is.null({{y}}))retornam Error: object 'y' not found. Qual é a melhor maneira de verificar a presença de y, quando y é uma coluna de data frame em vez de um objeto independente?

  • 3 3 respostas
  • 79 Views

3 respostas

  • Voted
  1. Best Answer
    Axeman
    2025-02-09T07:53:02+08:002025-02-09T07:53:02+08:00

    Uma opção é verificar se a yvariável é missing, em vez de usá-la NULLcomo um espaço reservado.

    sample_fun <- function(df, x, y) {
      if (!missing(y)) {
        df <- mutate(df, z = {{x}} * {{y}})
      } else {
        df <- mutate(df, z = {{x}})
      }
      return(df)
    }
    df_out <- sample_fun(df, x) 
    df_out2 <- sample_fun(df, x, y)
    
    • 3
  2. G. Grothendieck
    2025-02-09T10:36:46+08:002025-02-09T10:36:46+08:00

    O problema com o código na questão é que is.nullnão é possível pegar uma variável sem aspas. O código ali funcionaria se quo_is_null(enquo(y))fosse usado no lugar de is.null(y). Nesse caso, adicione a library(rlang)também.

    Como alternativa, forneça yum valor padrão de 1.

    library(dplyr)
    
    sample_fun <- function(df, x, y = 1) df %>% mutate(z = {{x}} * {{y}})
    
    sample_fun(df, x, y)
    ##   x  y  z
    ## 1 1 11 11
    ## 2 2 12 24
    ## 3 3 13 39
    ## 4 4 14 56
    ## 5 5 15 75
    
    sample_fun(df, x)
    ##   x  y z
    ## 1 1 11 1
    ## 2 2 12 2
    ## 3 3 13 3
    ## 4 4 14 4
    ## 5 5 15 5
    
    • 1
  3. jay.sf
    2025-02-09T12:44:11+08:002025-02-09T12:44:11+08:00

    Você poderia generalizar isso um pouco.

    sample_fun <- \(data, ..., FUN='*') {
      ell <- substitute(list(...))[-1]
      if (!is.null(ell)) {
        stopifnot(all(as.character(ell) %in% names(data)))
        expr <- Reduce(\(x, y) call(FUN, x, y), ell) 
        transform(data, z=eval(expr))
      } else data
    }
    

    > sample_fun(df, X1)
      X1 X2 X3 z
    1  1  3  5 1
    2  2  4  6 2
    > sample_fun(df, X1, X3)
      X1 X2 X3  z
    1  1  3  5  5
    2  2  4  6 12
    > sample_fun(df, X1, X2, X999)
    Error in sample_fun(df, X1, X2, X999) : 
      all(as.character(ell) %in% names(df)) is not TRUE
    > sample_fun(df)
      X1 X2 X3
    1  1  3  5
    2  2  4  6
    > sample_fun(df, X1, X2, FUN='/')
      X1 X2 X3         z
    1  1  3  5 0.3333333
    2  2  4  6 0.5000000
    

    Dados:

    > dput(df)
    structure(list(X1 = 1:2, X2 = 3:4, X3 = 5:6), class = "data.frame", row.names = c(NA, 
    -2L))
    
    • 0

relate perguntas

  • Adicionar número de série para atividade de cópia ao blob

  • A fonte dinâmica do empacotador duplica artefatos

  • Selecione linhas por grupo com 1s consecutivos

  • Lista de chamada de API de gráfico subscritoSkus estados Privilégios insuficientes enquanto os privilégios são concedidos

  • Função para criar DFs separados com base no valor da coluna

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve