子集时间序列(日期序列)到列表中

时间:2017-01-16 16:07:38

标签: r list dplyr

我有一个包含一系列日期的数据框,以下是它的简化版本:

> eventdates
  dr.rank   dr.start     dr.end
1      14 1964-09-30 1964-10-06
2      16 1964-11-01 1964-12-24

我还有一个时间序列的日期,其值与此相关,这里是时间序列的简化版本:

ts1964 <- data.frame(DATE = seq(from = as.Date("1964-01-01"), to = as.Date("1964-12-31"), by = "days"),
                     Q = 1:366)

我要做的是按事件日期中的每个日期进行子集,即:

> filter(ts1964, ts1964$DATE >= eventdates[1,2] & ts1964$DATE <= eventdates[1,3])
         DATE   Q
1  1964-09-30 274
2  1964-10-01 275
3  1964-10-02 276
4  1964-10-03 277
5  1964-10-04 278
6  1964-10-05 279
7  1964-10-06 280
8  1964-10-07 281
9  1964-10-08 282
10 1964-10-09 283
11 1964-10-10 284
12 1964-10-11 285
13 1964-10-12 286
14 1964-10-13 287
15 1964-10-14 288
16 1964-10-15 289
17 1964-10-16 290
18 1964-10-17 291
19 1964-10-18 292
20 1964-10-19 293
21 1964-10-20 294
22 1964-10-21 295
23 1964-10-22 296
24 1964-10-23 297
25 1964-10-24 298
26 1964-10-25 299
27 1964-10-26 300
28 1964-10-27 301
29 1964-10-28 302
30 1964-10-29 303
31 1964-10-30 304
32 1964-10-31 305
33 1964-11-01 306
> 

但我需要这样做数百次。我想要做的是让每个子集在列表中形成一个元素。我通常会考虑在dlply中使用plyr之类的内容,但在使用dplyr时这不是一个选项。任何人都可以建议我如何实现这一目标吗?感谢

1 个答案:

答案 0 :(得分:4)

我们可以使用Map

Map(function(x,y) filter(ts1964, DATE >= x & DATE <= y), 
                    eventdates$dr.start, eventdates$dr.end)