如何从丢弃日期部分的一系列POSIXct对象中提取时间?
例如,我有:
times <- structure(c(1331086009.50098, 1331091427.42461, 1331252565.99979,
1331252675.81601, 1331262597.72474, 1331262641.11786, 1331269557.4059,
1331278779.26727, 1331448476.96126, 1331452596.13806), class = c("POSIXct",
"POSIXt"))
对应于这些日期:
"2012-03-07 03:06:49 CET" "2012-03-07 04:37:07 CET"
"2012-03-09 01:22:45 CET" "2012-03-09 01:24:35 CET"
"2012-03-09 04:09:57 CET" "2012-03-09 04:10:41 CET"
"2012-03-09 06:05:57 CET" "2012-03-09 08:39:39 CET"
"2012-03-11 07:47:56 CET" "2012-03-11 08:56:36 CET"
现在,我有一些在这些时间测量的参数的值
val <- c(1.25343125e-05, 0.00022890575,
3.9269125e-05, 0.0002285681875,
4.26353125e-05, 5.982625e-05,
2.09575e-05, 0.0001516951251,
2.653125e-05, 0.0001021391875)
我想绘制val与当天的时间,而不考虑测量val的具体日期。
是否有允许我这样做的特定功能?
答案 0 :(得分:93)
您可以使用strftime
将日期时间转换为任何字符格式:
> t <- strftime(times, format="%H:%M:%S")
> t
[1] "02:06:49" "03:37:07" "00:22:45" "00:24:35" "03:09:57" "03:10:41"
[7] "05:05:57" "07:39:39" "06:47:56" "07:56:36"
但这并没有多大帮助,因为你想绘制你的数据。一种解决方法是从您的时间中删除日期元素,然后在所有时间添加相同的日期:
> xx <- as.POSIXct(t, format="%H:%M:%S")
> xx
[1] "2012-03-23 02:06:49 GMT" "2012-03-23 03:37:07 GMT"
[3] "2012-03-23 00:22:45 GMT" "2012-03-23 00:24:35 GMT"
[5] "2012-03-23 03:09:57 GMT" "2012-03-23 03:10:41 GMT"
[7] "2012-03-23 05:05:57 GMT" "2012-03-23 07:39:39 GMT"
[9] "2012-03-23 06:47:56 GMT" "2012-03-23 07:56:36 GMT"
现在,您可以在绘图中使用这些datetime
个对象:
plot(xx, rnorm(length(xx)), xlab="Time", ylab="Random value")
如需更多帮助,请参阅?DateTimeClasses
答案 1 :(得分:14)
以前的答案显示了这个伎俩。实质上:
您必须保留POSIXct
类型才能利用所有现有的绘图功能
如果你想在一个地块上“叠加”好几天,突出每日内变化,最好的伎俩也是......
施放同一天(如果需要,可以是月份甚至是年份,但这不是这种情况)
您可以通过在POSIXlt
表示中覆盖日期和月份组件,或者仅通过在不同日期之间相对于0:00:00偏移“delta”来执行此操作。
因此,您可以提供times
和val
:
## impose month and day based on first obs
ntimes <- as.POSIXlt(times) # convert to 'POSIX list type'
ntimes$mday <- ntimes[1]$mday # and $mon if it differs too
ntimes <- as.POSIXct(ntimes) # convert back
par(mfrow=c(2,1))
plot(times,val) # old times
plot(ntimes,val) # new times
产生了与原始和修改时间尺度形成鲜明对比的结果:
答案 2 :(得分:6)
data.table
程序包具有函数“ as.ITime
”,可以在下面有效地使用此功能:
library(data.table)
x <- "2012-03-07 03:06:49 CET"
as.IDate(x) # Output is "2012-03-07"
as.ITime(x) # Output is "03:06:49"
答案 3 :(得分:3)
我找不到任何完全符合时钟时间的内容,所以我只使用包中的一些函数:lubridate并使用秒 - 从午夜开始:
require(lubridate)
clockS = function(t){hour(t)*3600+minute(t)*60+second(t)}
plot(clockS(times),val)
然后,您可能需要查看一些轴代码,以确定如何很好地标记轴。
答案 4 :(得分:3)
午夜GMT的time_t
值始终可以被86400
(24 * 3600
)整除。因此,自格林威治标准时间午夜起的值为time %% 86400
。
GMT中的小时为(time %% 86400) / 3600
,这可以用作情节的x轴:
plot((as.numeric(times) %% 86400)/3600, val)
要调整时区,请通过添加时区超前GMT的秒数来调整模数前的时间。例如,美国中央夏令时(CDT)比GMT晚5个小时。要在CDT中绘制时间,请使用以下表达式:
plot(((as.numeric(times) - 5*3600) %% 86400)/3600, val)
答案 5 :(得分:3)
已经提供了许多解决方案,但我还没有看到这个使用包chron:
hours = times(strftime(times, format="%T"))
plot(val~hours)
(抱歉,我无权发布图片,你必须自己绘制图片)
答案 6 :(得分:1)
对于那些正在寻找一种tidyverse方法从POSIXct对象中提取hh:mm :: ss.sssss的人来说,这是一个更新。请注意,输出中不包含时区。
library(hms)
as_hms(times)