提取每个月的第一个星期一

use*_*635 4 r date

如何从2010-01-01到2015-12-31提取每个月的第一个星期一?

sco*_*coa 12

我们可以使用lubridate,wday测试这是否是星期一,并day测试这是否是该月的第一周:

library(lubridate)
x <- seq(ymd("2010-01-01"),ymd("2015-12-31"),by="1 day")
x[wday(x,label = TRUE) == "Mon" & day(x) <= 7]
Run Code Online (Sandbox Code Playgroud)

或者在base-r(@ DavidArenburg的评论)

x <- seq(as.Date("2010-01-01"), as.Date("2015-12-31"), by = "day")
# You need to adapt "Monday" to the equivalent in your locale
x[weekdays(x) == "Monday" & as.numeric(format(x, "%d")) <= 7]
Run Code Online (Sandbox Code Playgroud)

输出(五个第一结果)

[1] "2010-01-04 UTC" "2010-02-01 UTC" "2010-03-01 UTC" "2010-04-05 UTC" "2010-05-03 UTC" "2010-06-07 UTC"
Run Code Online (Sandbox Code Playgroud)

  • 或者只是`x < - seq(as.Date("2010-01-01"),as.Date("2015-12-31"),by ="day"); x [weekdays(x)=="Monday"&as.numeric(format(x,"%d"))<= 7]`with base R (7认同)

luk*_*keA 5

另一个apprach:使用Boost Date_Time库:

library(RcppBDT)
dates <- seq(as.Date("2010-01-01"), as.Date("2015-12-31"), by="1 month")
do.call(c, lapply(dates-1, getFirstDayOfWeekAfter, dow=Mon))
# [1] "2010-01-04" "2010-02-01" "2010-03-01" "2010-04-05" "2010-05-03"...
Run Code Online (Sandbox Code Playgroud)