Total_Solar_Gesamt <- read.table(header=TRUE, sep=",", text="
Timedate, TotalSolar_MW
2013-06-01 04:45:00, 13.0
2013-06-01 05:00:00, 41.7
2013-06-01 05:15:00, 81.8
2013-06-01 05:30:00, 153.0
2013-06-01 05:45:00, 270.7
2013-06-01 06:00:00, 429.3
2013-06-01 06:15:00, 535.4
")
使用cut.POSIXt
的日期分爲每小時一班:
Sum <- aggregate(Total_Solar_Gesamt["TotalSolar_MW"],
list(hour=cut(as.POSIXct(Total_Solar_Gesamt$Timedate), "hour")),
sum)
Sum
hour TotalSolar_MW
1 2013-06-01 04:00:00 13.0
2 2013-06-01 05:00:00 547.2
3 2013-06-01 06:00:00 964.7
注意上面的意志集團06:00:00與其他06倍。如果你想組與前一小時一小時的頂部,只是從每個時間戳減一第二種:
Sum2 <- aggregate(Total_Solar_Gesamt["TotalSolar_MW"],
list(hour=cut(as.POSIXct(Total_Solar_Gesamt$Timedate)-1, "hour")),
sum)
Sum2
hour TotalSolar_MW
1 2013-06-01 04:00:00 54.7
2 2013-06-01 05:00:00 934.8
3 2013-06-01 06:00:00 535.4
而且,如果你想在一小時前報告您的日期,就像在你的問題:
Sum2$adjustedHour <- as.POSIXct(Sum2$hour) + 3600
Sum2
hour TotalSolar_MW adjustedHour
1 2013-06-01 04:00:00 54.7 2013-06-01 05:00:00
2 2013-06-01 05:00:00 934.8 2013-06-01 06:00:00
3 2013-06-01 06:00:00 535.4 2013-06-01 07:00:00
使用XTS:
library(xts)
data.xts <- xts(Total_Solar_Gesamt$TotalSolar_MW,
as.POSIXct(Total_Solar_Gesamt$Timedate)-1)
# subtract 1 second, as discussed above
Sum.xts <- period.apply(data.xts, INDEX=endpoints(data.xts, "hours"), FUN=sum)
Sum.xts
[,1]
2013-06-01 04:59:59 54.7
2013-06-01 05:59:59 934.8
2013-06-01 06:14:59 535.4
注意如何與XTS,在Sum.xts
的時間戳是洛杉磯每小時的時間戳。 XTS可以很容易地對齊,雖然他們:
Sum.xts <- align.time(Sum.xts, 3600) # round up to next hour
Sum.xts
[,1]
2013-06-01 05:00:00 54.7
2013-06-01 06:00:00 934.8
2013-06-01 07:00:00 535.4
請務必提供[**重複的例子,**](http://stackoverflow.com/questions/5963269/how-to-make-a-great -r-reproducible-example)爲您的問題。 – Arun
除了缺少可重複使用的示例,一般建議,避免使用** POSIXlt **,它是**列表** /不是數字,很難用於分組。 – agstudy
對不起!我在這裏很新,忘記了可重複的例子 –