将列转换为POSIXct日期/时间序列

问题描述 投票:0回答:1

我正在尝试将数据格式(str ='character')中的列重新配置为日期/时间序列列(str = POSIXct),其格式为'MM / DD / YYYY HH:MM:SS'与rmweather软件包一起使用。

> DNO2$`Date & Time`
    `Date & Time`
    <dttm>  
[1] "31/12/2017 24:00" 
[2] "01/01/2018 01:00"
[3] "01/01/2018 02:00" 
[4] "01/01/2018 03:00"
[5] "01/01/2018 04:00" 
[6] "01/01/2018 05:00"

简而言之,我想从:'MM / DD / YYYY HH:MM:SS'至:'YYYY-MM-DD HH:MM:SS'

我尝试使用as_datetime()包中的lubridate函数来执行此操作,但收到一个奇怪的输出:

> DNO_18$`Date & Time` <- as_datetime(DNO_18$`Date & Time`, tz="Europe/London")
> head(DNO_18)
# A tibble: 6 x 8
  `Date & Time`       Rathmines Ringsend `St John`
  <dttm>              <chr>     <chr>    <chr>           
1 2031-12-20 17:24:00 0.299999… 0.90000… NoData          
2 2001-01-20 18:01:00 0.299999… 0.80000… NoData          
3 2001-01-20 18:02:00 0.299999… 0.90000… NoData          
4 2001-01-20 18:03:00 0.100000… 0.80000… NoData          
5 2001-01-20 18:04:00 0.200000… 1        NoData          
6 2001-01-20 18:05:00 0.200000… 0.90000… NoData    

任何帮助,我们将不胜感激。

r date time posixct
1个回答
0
投票

我们可以使用as.POSIXct中的base R

DNO_18$`Date & Time` <- as.POSIXct(DNO_18$`Date & Time`, format = "%d/%m/%Y %H:%M")

或带有lubridate

library(lubridate)
DNO_18$`Date & Time` <- dmy_hm(DNO_18$`Date & Time`)
© www.soinside.com 2019 - 2024. All rights reserved.