R - 以字符,时间和日期变量为条件的嵌套ifelse错误

时间:2018-06-01 10:14:51

标签: r if-statement dataframe nested difftime

此问题基本上是对我的以下帖子R - Conditional operations on time variables and dates

的扩展

我遇到的问题是由于嵌套ifelse语句形式的扩展中出现错误(例如,参见https://www.listendata.com/2017/03/if-else-in-r.html)@griffinevo的解决方案。假设我有不同的当地证券交易所的关闭时间(同一时区)我想使用嵌套的ifelse语句,以便能够在几个关闭时间之间进行distingush。但问题是以下错误:

     Error in ifelse(StockExchanges %in% c("Vienna"), difftime(as.POSIXct(HMS,  : 
  unused argument (ifelse(StockExchanges %in% c("Frankfurt"), difftime(as.POSIXct("22:00:00", format = "%H:%M:%S")) > 0, as.character(TimeStamp + 1), ifelse(StockExchanges %in% c("Frankfurt"), difftime(as.POSIXct("22:00:00", format = "%H:%M:%S")) > 0, as.character(TimeStamp + 1), as.character(TimeStamp))))

我的语法似乎有误,但我不知道到底出了什么问题。

假设我有以下3个证券交易所:维也纳,法兰克福和汉堡以及不同的收盘时间。我想创建一个新变量TimeStampNew,如果变量HMS在几个证券交易所的关键关闭时间之后,则将日期增加一。这里是数据帧df的第一行。

   TimeStamp      HMS StockExchange
     1: 2013-09-15 19:54:00        Vienna
     2: 2016-05-10 18:58:00        Vienna
     3: 2014-09-22 22:47:00        Hamburg
     4: 2012-01-30 18:03:00        Frankfurt
     5: 2013-05-24 08:00:00        Vienna
     6: 2013-06-07 11:45:00        Vienna
     7: 2016-11-30 12:39:00        Vienna
     8: 2007-03-28 NA              Vienna
     9: 2007-05-10 NA              Hamburg
    10: 2007-08-09 NA              Vienna
    11: 2007-11-08 NA              Frankfurt
    12: 2008-03-27 NA              Vienna

这是我产生上述错误的语法:

   df$TimeStampNew <-
 with(df, 
      ifelse(StockExchanges %in% c("Vienna") , 
             difftime(as.POSIXct(HMS, format = "%H:%M:%S"), 
                      as.POSIXct("17:35:00", format = "%H:%M:%S")) > 0,
             as.character(TimeStamp + 1),
      ifelse(StockExchanges %in% c("Frankfurt") , 
             difftime(as.POSIXct("22:00:00", format = "%H:%M:%S")) > 0,
             as.character(TimeStamp + 1),
      ifelse(StockExchanges %in% c("Hamburg") , 
             difftime(as.POSIXct("20:00:00", format = "%H:%M:%S")) > 0,
             as.character(TimeStamp + 1),
             as.character(TimeStamp)))))

df1$TimeStampNew[is.na(df1$HMS)] <- as.character(df1$TimeStamp[is.na(df1$HMS)])

是否有人知道错误发现的地方分别有另一种可能的解决方案?提前谢谢!

1 个答案:

答案 0 :(得分:1)

用于在ifelse中给出两个条件的语法是错误的。应该是这样的,

ifelse(StockExchanges %in% c("Vienna") & 
         difftime(as.POSIXct(HMS, format = "%H:%M:%S"),
                  as.POSIXct("17:35:00", format = "%H:%M:%S")) > 0,
         as.character(TimeStamp + 1),

即。这两个条件应该用'&amp;'分隔而不是逗号。 只需对所有ifelse条件进行更改,它就可以正常运行。