Импортируйте дату и время в указанном часовом поясе, не обращая внимания на летнее время - PullRequest
9 голосов
/ 04 ноября 2011

У меня есть данные временных рядов, полученные из регистратора данных, который был установлен на один часовой пояс без перехода на летнее время ( NZST или UTC + 12: 00), и данные охватывают несколько лет. Регистраторы данных не учитывают изменения DST и синхронизируются по местному времени с / без DST (в зависимости от того, кто его развернул).

Однако, когда я получаю данные в R, я не могу правильно использовать as.POSIXct, чтобы игнорировать DST. Я использую R 2.14.0 на компьютере Windows с этими настройками:

> Sys.timezone()
[1] "NZDT"
> Sys.getlocale("LC_TIME")
[1] "English_New Zealand.1252"

Вот три метки времени изменения весеннего перехода на летнее время, каждая разнесена на 1 час:

> ts_str <- c("28/09/2008 01:00", "28/09/2008 02:00", "28/09/2008 03:00")
> as.POSIXct(ts_str, format="%d/%m/%Y %H:%M", tz="")
[1] "2008-09-28 01:00:00 NZST" NA
[3] "2008-09-28 03:00:00 NZDT"
> as.POSIXct(ts_str, format="%d/%m/%Y %H:%M", tz="UTC")
[1] "2008-09-28 01:00:00 UTC" "2008-09-28 02:00:00 UTC"
[3] "2008-09-28 03:00:00 UTC"

Как видите, часы подскочили вперед с 1:59 до 3:00, поэтому 2:00 недействительно, то есть NA. Кроме того, я могу использовать tz="UTC", чтобы игнорировать изменения DST. Тем не менее, я бы предпочел сохранить правильный часовой пояс, поскольку у меня есть другие серии данных, записанные с DST (NZDT или UTC + 13: 00), которые я хотел бы объединить (через merge) для мой анализ.

Как настроить параметр tz на компьютере с MS Windows? Я пробовал много вещей, таких как «NZST», «Стандартное время Новой Зеландии», «UTC + 12: 00», «+1200» и т. Д., Но не повезло. Или я могу изменить некоторые другие настройки?

Ответы [ 2 ]

9 голосов
/ 04 ноября 2011

Вы можете использовать tz="Etc/GMT+12":

as.POSIXct(ts_str, format="%d/%m/%Y %H:%M", tz="Etc/GMT+12")
[1] "2008-09-28 01:00:00 GMT+12" "2008-09-28 02:00:00 GMT+12"
[3] "2008-09-28 03:00:00 GMT+12"

Для получения полного списка доступных часовых поясов, используйте

dir(file.path(R.home("share"),"zoneinfo"), recursive=TRUE)

. Там есть несколько файлов .tab, которые неэто часовые пояса, но они содержат некоторую информацию, но мое регулярное выражение недостаточно хорошо, чтобы можно было исключить их с аргументом шаблона dir.

1 голос
/ 04 ноября 2011

Если просто добавить 12 * 60 * 60 к этому производному в UTC вектору, у вас будет местное "стандартное" время.

...