R找到最后一个工作日

use*_*868 6 r date

如何使用R找到该月的最后一个工作日(例如,星期三)?在下面的代码中,我计算月份,月份日期,月份周和工作日.2014年1月有5个星期三,但2014年2月只有4个星期三,因此我不能使用max(月中的某个星期)作为过滤器.尽管我更喜欢使用基本R函数,但是我们对此感到满意.

DF <- data.frame(DATE = seq(as.Date("2014-01-01"), as.Date("2014-12-31"), "day"))

DF$MONTH         <- as.numeric(format(DF$DATE, "%m"))
DF$DAY_OF_MONTH  <- as.numeric(format(DF$DATE, "%d"))
DF$WEEK_OF_MONTH <- ceiling(as.numeric(format(DF$DATE, "%d")) / 7)
DF$WEEKDAY       <- format(DF$DATE, "%A")

DF
Run Code Online (Sandbox Code Playgroud)

Fra*_*ank 6

我想这就是你所追求的:

DF$last_weekday_o_month <- ave( 
  weekdays(DF$DATE), 
  months(DF$DATE), 
  FUN = function(x) tail(x[ !(x %in% c("Saturday","Sunday")) ], 1) 
)
Run Code Online (Sandbox Code Playgroud)

要查找最后一个工作日的特定日期....

DF$last_weekdaydate_o_month <- ave( 
  DF$DATE, 
  months(DF$DATE), 
  FUN = function(x) tail(x[ !(weekdays(x) %in% c("Saturday","Sunday")) ], 1) 
)
Run Code Online (Sandbox Code Playgroud)

结果看起来像......

          DATE last_weekday_o_month last_weekdaydate_o_month
1   2014-01-01               Friday               2014-01-31
2   2014-01-02               Friday               2014-01-31
3   2014-01-03               Friday               2014-01-31
4   2014-01-04               Friday               2014-01-31
5   2014-01-05               Friday               2014-01-31
6   2014-01-06               Friday               2014-01-31
...
360 2014-12-26            Wednesday               2014-12-31
361 2014-12-27            Wednesday               2014-12-31
362 2014-12-28            Wednesday               2014-12-31
363 2014-12-29            Wednesday               2014-12-31
364 2014-12-30            Wednesday               2014-12-31
365 2014-12-31            Wednesday               2014-12-31
Run Code Online (Sandbox Code Playgroud)

如果你先这样做,当然你可以计算last_weekday_o_monthweekdays(last_weekdaydate_o_month).


有了几个包,这可以更优雅/可读地完成,正如@RichardScriven建议的那样:

library(data.table)
setDT(DF)[, 
  last_weekdaydate_o_month := last(DATE[!chron::is.weekend(DATE)])
, by = month(DATE)]
Run Code Online (Sandbox Code Playgroud)

这使

           DATE last_weekdaydate_o_month
  1: 2014-01-01               2014-01-31
  2: 2014-01-02               2014-01-31
  3: 2014-01-03               2014-01-31
  4: 2014-01-04               2014-01-31
  5: 2014-01-05               2014-01-31
 ---                                    
361: 2014-12-27               2014-12-31
362: 2014-12-28               2014-12-31
363: 2014-12-29               2014-12-31
364: 2014-12-30               2014-12-31
365: 2014-12-31               2014-12-31
Run Code Online (Sandbox Code Playgroud)

  • `setDT(DF)[,last(DATE [!chron :: is.weekend(DATE)]),by = month(DATE)]`可能有用 (2认同)

cde*_*man 6

这是一个使用的方法dplyr.基本上你按月分组,过滤掉'周末'天并返回最后一天(即最大)日的工作日.

library(dplyr)

DF <- data.frame(DATE = seq(as.Date("2014-01-01"), as.Date("2014-12-31"), "day"))

DF %>%
  mutate(month = months(DATE), weekday = weekdays(DATE)) %>%
  group_by(month) %>%
  filter(!weekday %in% c("Saturday", "Sunday")) %>%
  summarise(last_weekday = weekdays(max(DATE))) 

Source: local data frame [12 x 2]

       month        last_weekday
1      April           Wednesday
2     August              Friday
3   December           Wednesday
4   February              Friday
5    January              Friday
6       July            Thursday
7       June              Monday
8      March              Monday
9        May              Friday
10  November              Friday
11   October              Friday
12 September             Tuesday
Run Code Online (Sandbox Code Playgroud)