我试图绘制从2015年4月7日开始,每15分钟收集一次的溪流水温数据,到2015年11月23日结束。我希望x轴的每个刻度都有标签,如“Apr”,“May”等,直到“Nov”。我编写的代码生成了一个漂亮的图形,但温度读数与x轴刻度标记错位;它们从2015年4月1日开始,而不是从2015年4月7日开始,因此所有温度读数都比应该早7天。换句话说,我希望x轴从4月1日开始,但数据从收集日期开始。我认为这与我如何排序时间并应用刻度有关,但我不确定如何纠正。非常感谢您的任何帮助。谢谢
#Load Data
trib<-read.csv("C:\\r.data\\trib.csv",header=TRUE)
#Index Time
trib$DateTime<-as.POSIXct(strptime(trib$DateTime,"%m/%d/%Y %H:%M"))
#Create Time Series
trib.xts<-xts(trib,order.by=trib$DateTime)
#Example Data
DateTime Temp
22666 2015-04-07 13:30:00 NA
22667 2015-04-07 13:45:00 2.983
22668 2015-04-07 14:00:00 3.142
22669 2015-04-07 14:15:00 3.274
22670 2015-04-07 14:30:00 3.354
22671 2015-04-07 14:45:00 3.433
22672 2015-04-07 15:00:00 3.485
22673 2015-04-07 15:15:00 3.670
22674 2015-04-07 15:30:00 3.749
22675 2015-04-07 15:45:00 3.827
#Plot
par(mfrow=c(1,1))
margins <- par(mar=c(2,2,1,1)+0.1)
omargins <- par(oma=c(2,2,0.5,0.5)+0.1)
Temp.lab=seq(0,30,by=5)
Temp.ticks=seq(0,30,by=5)
plot(trib.xts$Temp,axes=FALSE,auto.grid=FALSE,col="gray",ylim=c(0,30),main="Stream Name",cex.main=0.8,lwd=1)
axis(2,at=Temp.ticks,labels=format(Temp.lab,scientific=FALSE),ylab="Temperature (C)",las=1,cex.axis=0.8)
times <- time(trib.xts$DateTime["2015-04-01/2015-11-15"])
ticksm <- seq(times[1], times[length(times)], by = "months")
month.lab = c("Apr","May","Jun","Jul","Aug","Sep","Oct","Nov")
axis(1, at = ticksm, labels = month.lab, tcl = -0.5,cex.axis=0.8,xlab="Month")
mtext("Temperature (°C)",side=2,line=3,las=3,cex=0.8)
mtext("Month",side=1,line=3,cex=0.8)
plot.xts
方法将使用索引作为x轴定位。这进一步表明需要使用dput
作为输出函数。 - IRTFMdput(trib)
。我的read.csv
测试,使用 NA 的初始值且不指定 colClasses,表明你认为是数字的列可能是因子类别。 - IRTFM