-
-
Notifications
You must be signed in to change notification settings - Fork 16
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' into data_summary_ci
- Loading branch information
Showing
9 changed files
with
231 additions
and
83 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
test_that("value_at", { | ||
data(efc, package = "datawizard") | ||
expect_equal(value_at(efc$e42dep, 5), 4, ignore_attr = TRUE) | ||
expect_equal(value_at(efc$c12hour, 4), NA_real_, ignore_attr = TRUE) | ||
expect_equal(value_at(efc$c12hour, 4, remove_na = TRUE), 168, ignore_attr = TRUE) | ||
expect_equal(value_at(efc$c12hour, 5:7), efc$c12hour[5:7], ignore_attr = TRUE) | ||
expect_equal(value_at(efc$e42dep, 123456, default = 55), 55, ignore_attr = TRUE) | ||
expect_null(value_at(efc$e42dep, 123456)) | ||
expect_null(value_at(efc$e42dep, NULL)) | ||
expect_error(value_at(efc$e42dep, NA), regex = "`position` can't") | ||
expect_error(value_at(efc$e42dep, c(3, NA)), regex = "`position` can't") | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
#' @title Find the value(s) at a specific position in a variable | ||
#' @name value_at | ||
#' | ||
#' @description This function can be used to extract one or more values at a | ||
#' specific position in a variable. | ||
#' | ||
#' @param x A vector or factor. | ||
#' @param position An integer or a vector of integers, indicating the position(s) | ||
#' of the value(s) to be returned. Negative values are counted from the end of | ||
#' the vector. If `NA`, an error is thrown. | ||
#' @param remove_na Logical, if `TRUE`, missing values are removed before | ||
#' computing the position. If `FALSE`, missing values are included in the | ||
#' computation. | ||
#' @param default The value to be returned if the position is out of range. | ||
#' | ||
#' @seealso `data_summary()` to use `value_at()` inside a `data_summary()` call. | ||
#' | ||
#' @return A vector with the value(s) at the specified position(s). | ||
#' | ||
#' @examples | ||
#' data(mtcars) | ||
#' # 5th value | ||
#' value_at(mtcars$mpg, 5) | ||
#' # last value | ||
#' value_at(mtcars$mpg, -1) | ||
#' # out of range, return default | ||
#' value_at(mtcars$mpg, 150) | ||
#' # return 2nd and fifth value | ||
#' value_at(mtcars$mpg, c(2, 5)) | ||
#' @export | ||
value_at <- function(x, position = 1, default = NULL, remove_na = FALSE) { | ||
if (remove_na) { | ||
x <- x[!is.na(x)] | ||
} | ||
n <- length(x) | ||
unlist(lapply(position, .values_at, x = x, n = n, default = default), use.names = FALSE) | ||
} | ||
|
||
# helper ---- | ||
|
||
.values_at <- function(x, position, n, default) { | ||
if (is.na(position)) { | ||
insight::format_error("`position` can't be `NA`.") | ||
} | ||
if (position < 0L) { | ||
position <- position + n + 1 | ||
} | ||
if (position <= 0 || position > n) { | ||
return(default) | ||
} | ||
x[position] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.