我有一个包含日期列和其他一些值列的数据框。我想从数据框中提取日期列与预先存在的日期列表中的任何元素匹配的那些行。例如,使用一个元素的列表,日期“2012-01-01”将从数据框中提取日期为“2012-01-01”的行。
对于数字,我想我知道如何匹配这些值。这段代码:
testdf <- data.frame(mydate = seq(as.Date('2012-01-01'),
as.Date('2012-01-10'), by = 'day'),
col1 = 1:10,
col2 = 11:20,
col3 = 21:30)
...产生这个数据框:
mydate col1 col2 col3
1 2012-01-01 1 11 21
2 2012-01-02 2 12 22
3 2012-01-03 3 13 23
4 2012-01-04 4 14 24
5 2012-01-05 5 15 25
6 2012-01-06 6 16 26
7 2012-01-07 7 17 27
8 2012-01-08 8 18 28
9 2012-01-09 9 19 29
10 2012-01-10 10 20 30
我可以做这个:
testdf[which(testdf$col3 %in% c('25','29')),]
产生这个:
mydate col1 col2 col3
5 2012-01-05 5 15 25
9 2012-01-09 9 19 29
我可以将其概括为如下列表:
myvalues <- c('25','29')
testdf[which(testdf$col3 %in% myvalues),]
我得到相同的输出。所以我原以为我可以对日期使用相同的方法,但看来我错了。这样做:
testdf[which(testdf$mydate %in% c('2012-01-05','2012-01-09')),]
得到我这个:
[1] mydate col1 col2 col3
<0 rows> (or 0-length row.names)
并且在他们自己的列表中弹出日期 - 这是最终目标 - 也无济于事。我可以想办法用循环或应用函数来解决这个问题,但在我看来,对于可能相当普遍的要求,必须有一种更简单的方法。是不是我又忽略了一些简单的事情?
问:如何子集具有日期列且其值与日期列表之一匹配的数据框的那些行?