Nothing
#' Get and Set Hour Values
#'
#' Gets and sets hour values for date/time vectors.
#'
#' @inheritParams params
#' @param value A integer vector of the hour value(s).
#'
#' @return An integer vector (or the modified date/time vector).
#' @family set time
#' @seealso [dtt_hour_decimal()]
#' @export
#'
#' @examples
#' x <- as.POSIXct("1990-01-02 23:40:51")
#' dtt_hour(x)
#' dtt_hour(x) <- 01L
#' x
#'
#' x <- hms::as_hms("23:40:51")
#' dtt_hour(x)
#' dtt_hour(x) <- 01L
#' x
dtt_hour <- function(x, ...) {
UseMethod("dtt_hour")
}
#' @rdname dtt_hour
#' @export
`dtt_hour<-` <- function(x, value) {
UseMethod("dtt_hour<-")
}
#' @describeIn dtt_hour Get integer vector of hour values for a Date vector
#' @export
dtt_hour.Date <- function(x, ...) {
chk_unused(...)
rep(0L, length(x))
}
#' @describeIn dtt_hour Get integer vector of hour values for a POSIXct vector
#' @export
dtt_hour.POSIXct <- function(x, ...) {
chk_unused(...)
x <- as.POSIXlt(x, tz = dtt_tz(x))
as.integer(x$hour)
}
#' @describeIn dtt_hour Get integer vector of hour values for a hms vector
#' @export
dtt_hour.hms <- function(x, ...) {
chk_unused(...)
x <- dtt_time(x)
x <- as.POSIXlt(x)
as.integer(x$hour)
}
#' @describeIn dtt_hour Set hour values for a POSIXct vector
#' @export
`dtt_hour<-.POSIXct` <- function(x, value) {
chk_whole_numeric(value)
chk_subset(length(value), c(1L, length(x)))
chk_not_any_na(value)
if (!length(x)) {
return(x)
}
tz <- dtt_tz(x)
x <- as.POSIXlt(x, tz = tz)
x$hour <- value
as.POSIXct(format(x), tz = tz)
}
#' @describeIn dtt_hour Set hour values for a hms vector
#' @export
`dtt_hour<-.hms` <- function(x, value) {
chk_whole_numeric(value)
chk_not_any_na(value)
chk_range(value, c(0L, 23L))
chk_subset(length(value), c(1L, length(x)))
if (!length(x)) {
return(x)
}
x <- as.POSIXlt(x)
x$hour <- value
dtt_time(x)
}
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.