[英]Apply functions to hourly data in R
我在HISTORY表中具有以下數據,列名稱為:
ID, START_TIME, END_TIME, VALUE
51,2015-04-17 01:00:00,2015-04-17 01:10:00,98
51,2015-04-17 01:10:00,2015-04-17 01:20:00,96
51,2015-04-17 01:20:00,2015-04-17 01:30:00,97
51,2015-04-17 01:30:00,2015-04-17 01:40:00,99
51,2015-04-17 01:40:00,2015-04-17 01:50:00,98
51,2015-04-17 01:50:00,2015-04-17 02:00:00,105
51,2015-04-17 02:00:00,2015-04-17 02:10:00,103
51,2015-04-17 02:10:00,2015-04-17 02:20:00,101
51,2015-04-17 02:20:00,2015-04-17 02:30:00,100
51,2015-04-17 02:30:00,2015-04-17 02:40:00,104
51,2015-04-17 02:40:00,2015-04-17 02:50:00,102
51,2015-04-17 02:50:00,2015-04-17 03:00:00,98
51,2015-04-17 03:00:00,2015-04-17 03:10:00,97
51,2015-04-17 03:10:00,2015-04-17 03:20:00,96
51,2015-04-17 03:20:00,2015-04-17 03:30:00,99
51,2015-04-17 03:30:00,2015-04-17 03:40:00,100
51,2015-04-17 03:40:00,2015-04-17 03:50:00,101
51,2015-04-17 03:50:00,2015-04-17 04:00:00,102
51,2015-04-17 04:00:00,2015-04-17 04:10:00,99
51,2015-04-17 04:10:00,2015-04-17 04:20:00,104
51,2015-04-17 04:20:00,2015-04-17 04:30:00,105
51,2015-04-17 04:30:00,2015-04-17 04:40:00,103
51,2015-04-17 04:40:00,2015-04-17 04:50:00,98
51,2015-04-17 04:50:00,2015-04-17 05:00:00,97
51,2015-04-17 05:00:00,2015-04-17 05:10:00,101
51,2015-04-17 05:10:00,2015-04-17 05:20:00,103
51,2015-04-17 05:20:00,2015-04-17 05:30:00,101
51,2015-04-17 05:30:00,2015-04-17 05:40:00,105
51,2015-04-17 05:40:00,2015-04-17 05:50:00,102
51,2015-04-17 05:50:00,2015-04-17 06:00:00,98
我想將max()之類的函數應用於VALUE列,但要有一定的頻率。 如果頻率假設為1小時,則此功能將對5個不同的集合應用最大功能。
例如 從開始時間2015-04-17 01:00:00到2015-04-17 02:00:00等。 如何在R中實現這一目標。 最終輸出如下所示:
51, 2015-04-17 02:00:00, 105
51, 2015-04-17 03:00:00, 102
51, 2015-04-17 04:00:00, 104
51, 2015-04-17 05:00:00, 105
51, 2015-04-17 06:00:00, 105
其中上面的列是ID,START_TIME直到可計算出max()的值,該值是該小時內max()函數的結果。 如何在r中實現這一點。 使用間隔還是其他?
謝謝..
這是使用data.table
的另一種方式
library(data.table)
setDT(df)[, .(MAX_VALUE = max(VALUE)),
by = .(ID, START_TIME = as.POSIXct(START_TIME, format = "%F %H") + 3600)]
# ID START_TIME MAX_VALUE
# 1: 51 2015-04-17 02:00:00 105
# 2: 51 2015-04-17 03:00:00 104
# 3: 51 2015-04-17 04:00:00 102
# 4: 51 2015-04-17 05:00:00 105
# 5: 51 2015-04-17 06:00:00 105
或沒有任何軟件包依賴性的類似解決方案
df$START_TIME2 <- as.POSIXct(df$START_TIME, format = "%F %H") + 3600
aggregate(VALUE ~ ID + START_TIME2, df, max)
# ID START_TIME2 VALUE
# 1 51 2015-04-17 02:00:00 105
# 2 51 2015-04-17 03:00:00 104
# 3 51 2015-04-17 04:00:00 102
# 4 51 2015-04-17 05:00:00 105
# 5 51 2015-04-17 06:00:00 105
你可以試試
library(dplyr)
HISTORY %>%
group_by(ID, TIME = format(START_TIME + 60*60, "%Y-%m-%d %H:00:00")) %>%
summarise(MAX_VALUE = max(VALUE))
# ID TIME MAX_VALUE
# 1 51 2015-04-17 02:00:00 105
# 2 51 2015-04-17 03:00:00 104
# 3 51 2015-04-17 04:00:00 102
# 4 51 2015-04-17 05:00:00 105
# 5 51 2015-04-17 06:00:00 105
這是使用data.table
的可能解決方案
library(data.table)
setDT(df)[, max(VALUE), by = .(START_TIME = sub(":.*", "", START_TIME))]
START_TIME V1
1: 2015-04-17 01 105
2: 2015-04-17 02 104
3: 2015-04-17 03 102
4: 2015-04-17 04 105
5: 2015-04-17 05 105
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.