【发布时间】:2019-06-12 08:13:36
【问题描述】:
我有两个数据框 df1 和 df2 如下:
> df1
dateTime value
1 2018-06-27 00:00:01 6
2 2018-06-27 00:00:02 2
3 2018-06-27 00:00:03 3
4 2018-06-27 00:00:04 1
> df2
dateTime value
1 2018-06-27 00:00:01 3
2 2018-06-27 00:00:02 8
3 2018-06-27 00:00:03 4
4 2018-06-27 00:00:04 5
我想在一张图中绘制这些数据框,将它们分成两个具有相同x 轴的不同图,并将它们的名称添加到图的左上角。请注意,dateTime 是一个 POSIXct 对象。代码如下:
library(grid)
library(dplyr)
plot1 <- df1 %>%
select(dateTime, value) %>%
ggplot() +
geom_point(data = df1, aes(dateTime, value)) +
geom_line(data = df1, aes(x = dateTime, y = value), color = 'green') +
geom_text(aes(x = df1$dateTime[1], y = df1$value[1], label = "X Data"), color = "red", size = 7) +
theme(axis.text=element_text(size = 14), axis.title=element_text(size = 14),
axis.title.x=element_blank(),
axis.text.x=element_blank(),
axis.ticks.x=element_blank())
plot2 <- df2 %>%
select(dateTime, value) %>%
ggplot() +
geom_point(data = df2, aes(dateTime, value)) +
geom_line(data = df2, aes(x = dateTime, y = value), color = 'red') +
xlab("dateTime") +
geom_text(aes(x = df2$dateTime[1], y = df2$value[1]+5, label = "Y Data"), color = "green", size = 7) +
theme(axis.text=element_text(size = 14), axis.title=element_text(size = 14))
grid.newpage()
grid.draw(rbind(ggplotGrob(plot1), ggplotGrob(plot2), size = "last"))
结果是:
如您所见,X Data 和Y Data 在左上角,但我真的不喜欢手动更改geom_text 中的坐标来获得我想要的确切位置。有没有更好的方法可以在不手动更改坐标的情况下做到这一点?
【问题讨论】:
-
行绑定2个数据框和ID列,然后阅读facets。
-
cowplot::plot_grid(..., labels = )。骗子:Side-by-side plots with ggplot2