Nothing
knitr::opts_chunk$set(echo = TRUE)
ox
NULL
library(ox) x <- NULL y <- 1 # if (!is.null(x)) x else y xo(is.null, x, .else = y)
infinite
library(ox) x <- Inf y <- 1 # if (is.finite(x)) x else y xo(is.infinite, x, .else = y)
character(0)
x <- character(0) y <- 1 # if (!identical(x, character(0))) x else y xo(identical, x, character(0), .else = y)
x <- structure(0, class = "test") y <- 1 # if (inherits(x, "test")) x else y ox(inherits, x, "test", .else = y)
x <- 1 y <- 2 # if (x > y) x else y ox(`>`, x, y)
x <- "example text" y <- "alternative text" # if (grepl("text", x)) x else y ox(grepl, "text", x, .else = y)
x <- c("a", "b") y <- "a" # if (is.character(x) && length(x) == 1) x else y ox(function(x) is.character(x) && length(x) == 1, x, .else = y)
checkmate
if (require(checkmate)) { x <- c("a", "b") y <- "a" # if (test_character(x, len = 2)) x else y ox(test_character, x, len = 2, .else = y) }
magrittr
pipelibrary(magrittr) x <- "a" y <- 1 # x %<>% if (is.numeric(.)) . else y x %<>% ox(.f = is.numeric, .else = y)
OX
NA
with single valuex <- c(1, NA, 3) y <- 2 # x[is.na(x)] <- y[is.na(x)] XO(is.na, x, .else = y)
x <- c(1, 2, 3) y <- 0 x[which.min(x)] <- y XO(which.min, x, .else = y)
x <- c(1, 2, 3) y <- c(4, 3, 2) # x[x < y] <- y [x < y] OX(`>`, x, y)
x <- c(1, 2, 3, 4) # x[x > 2] OX(`>`, x, 2, .else = NULL)
x <- list(1, 2, 3, 4) # x[vapply(x, function(xx) xx > 2, logical(1))] OX(`>`, x, 2, .else = NULL)
dplyr::mutate
library(dplyr) iris %>% mutate(x = ifelse(Sepal.Length > Petal.Length, Sepal.Length, Petal.Length)) iris %>% mutate(x = OX(`>`, Sepal.Length, Petal.Length))
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.