簡體   English   中英

將 R 中的列轉換為 datetime 類型:as.POSIXct 返回 NA

[英]Converting a column in R to type datetime: as.POSIXct returns NA

我在嘗試將 char 類型的列轉換為日期時間時遇到了困難。

 Date.Time  Lat Lon Base
<chr>   <dbl>   <dbl>   <chr>
4/1/2014 0:11:00    40.7690 -73.9549    B02512
4/1/2014 0:17:00    40.7267 -74.0345    B02512
4/1/2014 0:21:00    40.7316 -73.9873    B02512
⋮   ⋮   ⋮   ⋮
4/30/2014 23:31:00  40.7443 -73.9889    B02764
4/30/2014 23:32:00  40.6756 -73.9405    B02764
4/30/2014 23:48:00  40.6880 -73.9608    B02764

使用變異:

df <- mutate(df, Date.Time = as.POSIXct(Date.Time,
                 format = "%M/%D%/%Y% %H:%M%S"))

雖然 Date.Time 的類型已從 to 更改,但整個列只是 NA。

Sys.getlocale() 的 Output:

'LC_CTYPE=en_US.UTF-8;LC_NUMERIC=C;LC_TIME=C;LC_COLLATE=en_US.UTF-8;LC_MONETARY=en_US.UTF-8;LC_MESSAGES=C;LC_PAPER=en_US.UTF-8;LC_NAME=C;LC_ADDRESS=C;LC_TELEPHONE=C;LC_MEASUREMENT=en_US.UTF-8;LC_IDENTIFICATION=C'

您輸入的格式代碼不正確。 應該是"%m/%d/%Y %H:%M:%S"而不是"%M/%D%/%Y% %H:%M%S" 其他一切都很好:

library(dplyr)

df <- read.table(header = TRUE, text = '
 Date.Time          Lat     Lon         Base
"4/1/2014 0:11:00"    40.7690 -73.9549    B02512
"4/1/2014 0:17:00"    40.7267 -74.0345    B02512
"4/1/2014 0:21:00"    40.7316 -73.9873    B02512
"4/30/2014 23:31:00"  40.7443 -73.9889    B02764
"4/30/2014 23:32:00"  40.6756 -73.9405    B02764
"4/30/2014 23:48:00"  40.6880 -73.9608    B02764')

df2 <- mutate(df, Date.Time = as.POSIXct(Date.Time, 
                                        format = "%m/%d/%Y %H:%M:%S"))

str(df2)
# 'data.frame': 6 obs. of  4 variables:
#   $ Date.Time: POSIXct, format: "2014-04-01 00:11:00" "2014-04-01 00:17:00" "2014-04-01 00:21:00" ...
# $ Lat      : num  40.8 40.7 40.7 40.7 40.7 ...
# $ Lon      : num  -74 -74 -74 -74 -73.9 ...
# $ Base     : chr  "B02512" "B02512" "B02512" "B02764" ...

您可以anytime使用該庫來執行此操作。 這是一個例子 -

date_var = "4/30/2014"

library(anytime)
anytime::anydate(date_var)

結果是

> "2014-04-30"

帶有lubridate的選項

library(dplyr)
library(lubridate)
df %>% 
  mutate(Date.Time = mdy_hms(Date.Time))

實際上,您的嘗試是非常正確的,只是格式錯誤。

as.POSIXct("4/1/2014 0:21:00", format = "%M/%D%/%Y% %H:%M%S")
#> [1] NA

如果在年和日之后刪除多余的 %,請在分鍾和秒之間添加缺少的:,並將年和月的代碼設為小寫字母(因為%M代表分鍾, %D%m/%d/%y:的縮寫%m/%d/%y: :

as.POSIXct("4/1/2014 0:21:00", format = "%m/%d/%Y %H:%M:%S")
#> [1] "2014-04-01 00:21:00 CEST"

代表 package (v1.0.0) 於 2021 年 2 月 14 日創建

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM