例如,给定两年的日期,我希望这个数据的输出是
c(1:12, 1:12)
:
data.frame(perf_dt = seq.Date(from = as.Date("2019-07-01"),
to = as.Date("2021-06-01"),
by = "month"))
我现在的功能是这个。它包括允许输出标签的逻辑。
FY_mo <- function(date, label = F, abbrev = F) {
a <- (5 + (lubridate::month(date) %% 12)) + 1
CY_num = lubridate::month(date)
ifelse(!label, a,
ifelse(abbrev,
month.abb[CY_num],
month.name[CY_num]))
}
当我为它提供单独的日期时,这是有效的。例如,此测试来自
testthat
通行证:
test_that("FY_mo works on indiv input dates", {
expect_equal(7, FY_mo(as.Date("2020-01-01")))
expect_equal("January", FY_mo(as.Date("2020-01-01"), label = TRUE))
expect_equal("Jan", FY_mo(as.Date("2020-01-01"), label = TRUE, abbrev = TRUE))
})
但是当我给它一个向量的时候它就不起作用了。下面的代码输出全部“13”。
data.frame(perf_dt = seq.Date(from = as.Date("2019-07-01"),
to = as.Date("2021-06-01"),
by = "month")) %>%
dplyr::mutate(FY_mo = FY_mo(perf_dt)) %>%
dplyr::pull(FY_mo)
#[1] 13 13 13 13 13 13 13 13 13 13 13 13 13 13 13 13 13 13 13 13 13 13 13 13
我的错在哪里?有没有更好的方法来构造函数以产生矢量的正确输出?