从分钟到天数

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (9)

想要从开始日期到结束日期创建一系列分钟,但在输出中将星期六和星期日分开。

我可以创建序列,但不知道如何遗漏星期六和星期日..

并且也不希望输出中的秒部分以及“IST”部分。

seq.POSIXt( as.POSIXct( "2019/06/21"), as.POSIXct( "2019/06/30"), "min")

如果有任何其他功能或方法可以更快或更简单地进行,将非常感激。TIA

提问于
用户回答回答于

生成序列后,您可以使用weekdays过滤掉星期六和星期日以外的日期,然后format以所需的格式输出。

all_time <- seq.POSIXt( as.POSIXct( "2019/06/21"), as.POSIXct( "2019/06/30"), "min")
format(all_time[!weekdays(all_time) %in% c("Saturday", "Sunday")], "%Y-%m-%d %H:%M")
# [1] "2019-06-21 00:00" "2019-06-21 00:01" "2019-06-21 00:02" "2019-06-21 00:03" 
#     "2019-06-21 00:04" "2019-06-21 00:05" "2019-06-21 00:06" "2019-06-21 00:07" 
#     "2019-06-21 00:08" "2019-06-21 00:09" ......

正如@thelatemail指出的那样weekdays是依赖于语言环境的,如果您有非英语语言环境,则上述操作无效。我们可以使用工作日来删除周末。

format(all_time[!format(all_time, "%u") %in% c(6, 7)], "%Y-%m-%d %H:%M")
用户回答回答于

使用库timeDate有助于:

library(timeDate)

have = seq.POSIXt( as.POSIXct( "2019/06/21"), as.POSIXct( "2019/06/30"), "min")
want = have[isWeekday(have)]

所属标签

可能回答问题的人

  • 学生

    3 粉丝476 提问8 回答
  • uncle_light

    5 粉丝518 提问7 回答
  • 最爱开车啦

    8 粉丝503 提问5 回答
  • 骑牛看晨曦

    4 粉丝522 提问5 回答

扫码关注云+社区

领取腾讯云代金券