【发布时间】:2017-08-12 08:50:48
【问题描述】:
我有这个以 30 分钟的步长记录的数据集:
structure(list(Particles = c(0.596667, 0.27, 0.153333, 0, 0.753333,
0, 0.35, 0.506667, 1.6, 0.116667), PM = c(35.5158928571429, 16.0714285714286,
9.12696428571429, 0, 44.84125, 0, 20.8333333333333, 30.15875,
95.2380952380953, 6.94446428571429), timestamp = c(1493310389147,
1493310419191, 1493310449254, 1493310479270, 1493310509313, 1493310539387,
1493310569416, 1493310599465, 1493310629525, 1502378711339),
date = structure(c(1493310389.147, 1493310419.191, 1493310449.254,
1493310479.27, 1493310509.313, 1493310539.387, 1493310569.416,
1493310599.465, 1493310629.525, 1502378711.339), class = c("POSIXct",
"POSIXt"), tzone = "UTC-1"), site = c("ABC", "ABC",
"ABC", "ABC", "ABC", "ABC",
"ABC", "ABC", "ABC", "ABC"
), code = c("ABC", "ABC", "ABC",
"ABC", "ABC", "ABC", "ABC",
"ABC", "ABC", "ABC"), key_date = c("2017-04-27",
"2017-04-27", "2017-04-27", "2017-04-27", "2017-04-27", "2017-04-27",
"2017-04-27", "2017-04-27", "2017-04-27", "2017-08-10")), .Names = c("Particles",
"PM", "timestamp", "date", "site", "code", "key_date"), row.names = c(NA,
10L), class = "data.frame")
如何将其聚合到每小时步数?我的列因一个数据框而异,因此我需要一种方法来聚合它,以便它也可以应用于其他数据框。
编辑:
我试过了:
res <- aggregate(Df['PM'], list(date = cut(as.POSIXct(Df$date), "1 hour")), sum)
但这只给我留下了两列,其余的都没有了。我该如何保留它们?
【问题讨论】:
-
如何使用
cut即df1 %>% group_by(Hour = cut(date, breaks = "hour")) %>% summarise(PM = sum(PM)) -
@akrun 我该怎么做?我收到此错误
Warning: Error in %>%: could not find function "%>%" -
我假设你有
library(dplyr); df1 %>% group_by(.. -
@akrun 现在可以正常工作了。谢谢。