无法使用scale包格式化x轴

时间:2013-04-16 15:31:03

标签: r ggplot2

我有这些数据并尝试使用ggplot2并进行缩放以格式化xaxis,具有日期和时间。

dput(head(pp))
structure(list(DateTime = structure(c(1362405600, 1362409200, 
1362412800, 1362416400, 1363006800, 1363010400), class = c("POSIXct", 
"POSIXt"), tzone = ""), Day = structure(c(1L, 1L, 1L, 1L, 1L, 
1L), .Label = c("Fri", "Mon", "Sat", "Sun", "Thu", "Tue", "Wed"
), class = "factor"), Total_Logins = c(818832L, 801771L, 787508L, 
731672L, 748872L, 727140L), Unique_Logins = c(732152L, 713380L, 
701348L, 647321L, 672848L, 649453L), Date = structure(c(15768, 
15768, 15768, 15768, 15775, 15775), class = "Date")), .Names = c("DateTime", 
"Day", "Total_Logins", "Unique_Logins", "Date"), row.names = c(1498L, 
1499L, 1500L, 1501L, 1666L, 1667L), class = "data.frame")

library(ggplot2)
library(scales)

ggplot(subset(pp, Day=="Fri"), aes(DateTime, Total_Logins, group=1)) + 
    geom_line() + 
    geom_smooth(method="loess", se=T, size=1) + 
    scale_x_date(breaks = "1 day", labels=date_format("%b-%d-%Y %H"))

我收到此错误:

  

错误:输入无效:date_trans仅适用于类Date的对象

我的日期时间列已经格式化了日期。任何想法,我在这里做错了什么?

enter image description here

1 个答案:

答案 0 :(得分:5)

由于列DateTime包含时间日期(类POSIXct),并且您还想显示x轴标签的小时,您应该使用scale_x_datetime()而不是scale_x_date()

+scale_x_datetime(breaks = "1 day", labels=date_format("%b-%d-%Y %H"))

要更改显示x轴刻度的中断,您可以将breaks="1 day"更改为breaks="6 hours"。另一种可能性是仅在实际值可用的地方显示休息时间。如果轴文本项太多,则可以更改文本的方向。

+scale_x_datetime(breaks = unique(pp$DateTime), labels=date_format("%b-%d-%Y %H"))+
        theme(axis.text.x=element_text(angle=90,vjust=0.5))