我正在处理一个只有年和月组件的月变量的 data.frame。我的部分数据如下:

     month         DIV  MKTP
1  1941-12 0.005752218 -4.87
2  1942-01 0.005767111  0.79
3  1942-02 0.005781771 -2.46
4  1942-03 0.005859665 -6.58
5  1942-04 0.005906924 -4.37
6  1942-05 0.005890041  5.94
7  1942-06 0.005941640  2.69
8  1942-07 0.005962464  3.51
9  1942-08 0.005936732  1.80
10 1942-09 0.006007593  2.61

我想将月份变量转换为 yearmon 格式以进行子集化。我的代码如下:
require(zoo,dplyr)
  df %>%
  mutate(month = as.yearmon(month)) %>%
  filter(month >= as.yearmon("1942-3") & month <= as.yearmon("1942-8"))

我想知道 lubridate 包是否具有与 yearmon 类似的功能,可以输入年和月的组合。

最佳答案

我们可以使用 filter , year 函数将 month 转换为带有 Dateymd

library(tidyverse)
df %>%
   mutate(date = ymd(paste0(month, "-01"))) %>%
   filter(year(date)>= 1942, month(date)>3, month(date)<=8, year(date) < 1943) %>%
   select(-date)

关于r - lubridate有类似zoo的yearmon功能吗?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/43533582/

10-14 07:32