我正在绘制许多时间序列图,并且需要具有一致的 x 值范围(日期)来比较这些图。我尝试使用expand_limits,但没有用。修复它的最佳方法是什么?我应该使用continuous_scale吗?
这会产生不同的范围:
library(ggplot2)
#Example Data
ID <- c(rep(1, 3), rep(2, 3))
date1 <- as.Date(c("2015-02-01", "2015-03-01", "2015-04-01",
"2015-03-01", "2015-03-15", "2015-03-31"), "%Y-%m-%d")
v1 <- rep(1:3, 2)
df <- data.frame(ID, date1, v1)
df
p1 <- ggplot(df[df$ID == 1,], aes(x = date1, y = v1)) +
geom_point(size = 3, colour = "#0000FF")
p2 <- ggplot(df[df$ID == 2,], aes(x = date1, y = v1)) +
geom_point(size = 3, colour = "#0000FF")
plot(p1)
plot(p2)
Run Code Online (Sandbox Code Playgroud)
这就是我试图修复它的方式:
p2 <- ggplot(df[df$ID == 2,], aes(x = date1, y = v1)) +
geom_point(size = 3, colour = "#0000FF") +
expand_limits(x = c("2015-02-01", "2015-04-01"))
plot(p2)
Run Code Online (Sandbox Code Playgroud)
这是错误: Error: Invalid input: date_trans works with objects of class Date only
谢谢!
小智 5
尝试与添加as.Date在expand_limits:
p2 <- ggplot(df[df$ID == 2,], aes(x = date1, y = v1)) +
geom_point(size = 3, colour = "#0000FF") +
expand_limits(x = as.Date(c("2015-02-01", "2015-04-01")))
print(p2)
Run Code Online (Sandbox Code Playgroud)

| 归档时间: |
|
| 查看次数: |
1536 次 |
| 最近记录: |