我的問題來自this question。問題有以下字符串。將chr「00:00:00」轉換爲日期時間「00:00:00」
x <- "2007-02-01 00:00:00"
y <- "02/01/2007 00:06:10"
如果您嘗試將此字符串轉換爲日期類對象,會發生一些有趣的事情。
這是@ nrusell的回答的一個示例。
as.POSIXct(x,tz=Sys.timezone())
[1] "2007-02-01 EST"
as.POSIXct(y,format="%m/%d/%Y %H:%M:%S",tz=Sys.timezone())
[1] "2007-02-01 00:06:10 EST"
如您所見,00:00:00
從第一個示例中消失。 @Richard Scriven在我們的討論中使用lubridate
留下了下面的例子。
dt <- as.POSIXct("2007-02-01 00:00:00")
hour(dt) <- hour(dt)+1
dt
[1] "2007-02-01 01:00:00 EST"
hour(dt) <- hour(dt)-1
dt
[1] "2007-02-01 EST"
再一次,00:00:00
消失。爲什麼R在轉換後避免在日期類對象中保留00:00:00
?我們如何保持00:00:00
?
什麼是更奇怪的是,如果你做'n < - now()',然後使用'hou r <-','minute <-'和'second <-'使它們全部歸零,午夜實際上保持不變。的古怪。這可能是一個「不完美」,並在R中進行日期處理。 – 2014-09-21 22:37:06
@RichardScriven:我認爲這是一個缺陷。 OP的問題根本不是問題。這與爭論的一個問題類似,即數字1不會將小數點右邊的零打印出來。 – 2014-09-21 22:42:34
@JoshuaUlrich但午夜是一天的實際時間,所以不應該這樣打印? – 2014-09-21 22:43:26