web-dev-qa-db-ja.com

POSIXctオブジェクトのタイムゾーンを変更する

RではdateTimesとタイムゾーンで遊ぶのが難しい場合があります。私の質問は次のとおりです。POSIXctオブジェクトのタイムゾーンを変更したい

R) data <- data.frame(x=c(1,2),dateTime=as.POSIXct(c("2010-03-11 03:30:00.432","2010-03-15 03:30:00.432"),format="%Y-%m-%d %H:%M:%S",tz="America/Montreal"))
R) data
  x            dateTime
1 1 2010-03-11 03:30:00
2 2 2010-03-15 03:30:00
R) str(data)
'data.frame':   2 obs. of  2 variables:
 $ x       : num  1 2
 $ dateTime: POSIXct, format: "2010-03-11 03:30:00" "2010-03-15 03:30:00"

しかし、タイムゾーンを変更したい場合、私が見つけた唯一のものは:

R) data$dateTime2 = format(data$dateTime,tz="Europe/Paris")
R) str(data)
'data.frame':   2 obs. of  3 variables:
 $ x        : num  1 2
 $ dateTime : POSIXct, format: "2010-03-11 03:30:00" "2010-03-15 03:30:00"
 $ dateTime2: chr  "2010-03-11 09:30:00" "2010-03-15 08:30:00"

または

R) data$dateTime2 = as.POSIXlt(data$dateTime,tz="Europe/Paris")
R) str(data)
'data.frame':   2 obs. of  3 variables:
 $ x        : num  1 2
 $ dateTime : POSIXct, format: "2010-03-11 03:30:00" "2010-03-15 03:30:00"
 $ dateTime2: POSIXlt, format: "2010-03-11 09:30:00" "2010-03-15 08:30:00"

神(またはSOの誰か)はPOSIXctで動作しない理由を知っています

R) data$dateTime2 = as.POSIXct(data$dateTime,tz="Europe/Paris")
R) str(data)
'data.frame':   2 obs. of  3 variables:
 $ x        : num  1 2
 $ dateTime : POSIXct, format: "2010-03-11 03:30:00" "2010-03-15 03:30:00"
 $ dateTime2: POSIXct, format: "2010-03-11 03:30:00" "2010-03-15 03:30:00"

characterに変換し、POSIXctにキャストする必要がありますか?

40
statquant

POSIXctでは機能しません。なぜならbase::as.POSIXct.defaultは、既にxである場合、単にPOSIXctを返します。 tzone属性を使用してタイムゾーンを変更できます。

attr(data$dateTime, "tzone") <- "Europe/Paris"
48
Joshua Ulrich

lubridateパッケージには、タイムゾーン属性を変更する関数with_tzがあります(事実上Joshuaが説明したもの)。

dttm <- as.POSIXct("2016-01-01 10:10:10", tz = "UTC")
dttm
[1] "2016-01-01 10:10:10 UTC"

タイムゾーンをUTCからCETに変更します

with_tz(dttm, "CET")
[1] "2016-01-01 11:10:10 CET"
22
Mark Heckmann