R/isYear.R

Defines functions isYear

Documented in isYear

#' isYear
#'
#' Function to find out whether a vector consists of strings in the format
#' "yXXXX" or "XXXX" with X being a number
#'
#'
#' @param x A vector
#' @param with_y indicates which dataformat years have to have (4-digit without
#' y (e.g.1984) or 5digit including y (y1984))
#' @return Returns a vector of the length of x with TRUE and FALSE
#' @author Benjamin Bodirsky
#' @examples
#'
#' x <- c("1955", "y1853", "12a4")
#' isYear(x, with_y = TRUE)
#' isYear(x, with_y = FALSE)
#' @export
isYear <- function(x, with_y = TRUE) { #nolint
  if (is.null(x)) return(FALSE)
  if (!is.vector(x)) {
    stop("Year Object is no Vector")
  }
  returnVector <- rep(TRUE, length(x))
  for (i in seq_along(x)) {
    if (with_y == FALSE) {
      if (nchar(x[i]) != 4) {
        returnVector[i] <- FALSE
      }
      if (grepl("[0-9]{4}", x[i]) == FALSE) {
        returnVector[i] <- FALSE
      }
    } else        {
      if (nchar(x[i]) != 5) {
        returnVector[i] <- FALSE
      }
      if (grepl("y[0-9]{4}", x[i]) == FALSE) {
        returnVector[i] <- FALSE
      }
    }
  }
  return(returnVector)
}
pik-piam/magclass documentation built on March 25, 2024, 11:07 p.m.