Вы можете вставить столбцы времени вместе и преобразовать их as.POSIXct
.
Как уже указывалось @ PavoDive , нам понадобятся числовые столбцы времени.Проверьте свой код, который произвел данные, или преобразуйте в числовое значение с помощью d[1:4] <- Map(function(x) as.numeric(as.character(x)), d[1:4])
.
Теперь paste
строк с apply
, преобразуйте as.POSIXct
и cbind
в остаток.sprintf
сначала смотрит, что все значения перед вставкой имеют одинаковые цифры.
d2 <- cbind(time=as.POSIXct(apply(sapply(d[1:4], sprintf, fmt="%02d"), 1, paste, collapse=""),
format="%m%d%H%M"),
d[5:6])
Графики хорошо, здесь в базе R:
with(d2, plot(time, t.site1, ylim=c(15, 17), xaxt="n",
xlab="time", ylab="value", type="b", col="red",
main="Time series"))
with(d2, lines(time, t.site2, type="b", col="green"))
mtext(strftime(d2$time, "%H:%M"), 1, 1, at=d2$time) # strftime gives the desired formatting
legend("bottomright", names(d2)[2:3], col=c("red", "green"), lty=rep(1, 2))
data:image/s3,"s3://crabby-images/5cae8/5cae805b05a0d698b1c5636329d936d504766079" alt="enter image description here"
Данные
d <- structure(list(month = structure(c(1L, 1L, 1L, 1L, 1L, 1L), .Label = "2", class = "factor"),
day = structure(c(1L, 1L, 1L, 1L, 1L, 1L), .Label = "1", class = "factor"),
h = structure(c(1L, 1L, 1L, 1L, 1L, 1L), .Label = "0", class = "factor"),
min = structure(1:6, .Label = c("0", "10", "20", "30", "40",
"50"), class = "factor"), t.site1 = c(15.485, 15.509, 15.557,
15.557, 15.605, 15.605), t.site2 = c(16.773, 16.773, 16.773,
16.773, 16.773, 16.773)), row.names = c(NA, -6L), class = "data.frame")