我有一个带有时间戳和值的数据框(一个月大约每 5 分钟就有一个值)。
现在我想要绘制 x 轴为日期、y 轴为一天中的时间、颜色为值的绘图。最好的是,如果我可以控制 y 轴上的分箱(5 分钟、10 分钟、15 分钟......其值为每个箱的平均值)。
我正在尝试 ggplot2,但无法得到合理的结果。
p_heat <- ggplot(data = data,
aes(x = days(timestamp),
y = minutes(timestamp) + hours(timestamp) * 60, fill = value)) +
geom_tile()
测试数据可以如下生成:
data <- data.frame(timestamp = seq(from = as.POSIXct("2013-09-01 00:00:00"),
to = as.POSIXct("2013-10-01 00:00:00"), by = "5 mins"),
value = runif(8641, 0, 1))
这是迄今为止我能得到的最好的:)
我也尝试使用scale_x_date()
我很高兴能得到一些提示,将我推向正确的方向。谢谢!
您正在寻找类似的东西吗?
library(ggplot2)
# create date variable for the x-axis
df$date <- as.Date(df$timestamp, format = "%Y-%m-%d")
# get H:M components
df$hm <- format(df$timestamp, "%H:%M")
# create y-axis breaks and labels
lab <- with(df, paste(format(df$timestamp, "%H"), "00", sep = ":"))
gg <- ggplot(data = df, aes(x = date, y = hm, fill = value)) +
geom_tile() +
scale_y_discrete(breaks = lab)
gg
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)