-
-
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.
informative error for incorrect length, add "value_at()" function
- Loading branch information
1 parent
5760b35
commit 3d854f8
Showing
7 changed files
with
129 additions
and
0 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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
#' @title Find the value at a specific position in a variable | ||
#' @name value_at | ||
#' | ||
#' @description This function can be used to compute summary statistics for a | ||
#' data frame or a matrix. | ||
#' | ||
#' @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. | ||
#' | ||
#' @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] | ||
} |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
test_that("value_at", { | ||
data(efc, package = "datawizard") | ||
expect_equal(value_at(efc$e42dep, 5), 4, ignore_attr = TRUE) | ||
expect_equal(value_at(efc$e42dep, 4), NA, ignore_attr = TRUE) | ||
expect_equal(value_at(efc$e42dep, 4, remove_na = TRUE), 4, 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)) | ||
}) |