Добавьте правильный век к датам с указанием года "Год без века",% y - PullRequest
14 голосов
/ 01 марта 2012

У меня есть файл с днями рождения в формате %d%b%y. Некоторые например.

# "01DEC71" "01AUG54" "01APR81" "01MAY81" "01SEP83" "01FEB59"

Я пытался переформатировать дату как

o108$fmtbirth <- format(as.Date(o108$birth, "%d%b%y"), "%Y/%m/%d")

и это результат

# "1971/12/01" "2054/08/01" "1981/04/01" "1981/05/01" "1983/09/01" "2059/02/01"

Это дни рождения, и я вижу 2054. Из этой страницы я вижу, что значения года между 00 и 68 кодируются как 20 для столетия. Есть ли способ переключить это, в моем случае я хочу, чтобы только от 00 до 12 было закодировано как 20.

Ответы [ 2 ]

26 голосов
/ 01 марта 2012

1) хрон .chron использует 30 по умолчанию, поэтому он преобразует их сначала в Date (поскольку chron не может прочитать такие даты), переформатируя его в символ с двузначными годами в формат, который chron может понять, и, наконец, обратно в Date.

library(chron)
xx <- c("01AUG11", "01AUG12", "01AUG13") # sample data
as.Date(chron(format(as.Date(xx, "%d%b%y"), "%m/%d/%y")))

Это дает отсечение 30, но мы можем получить отсечение 13, используя опцию chron.year.expand хрон:

library(chron)
options(chron.year.expand = 
     function (y, cut.off = 12, century = c(1900, 2000), ...) {
        chron:::year.expand(y, cut.off = cut.off, century = century, ...)
     }
)

и затем повторив исходное преобразование.Например, предполагая, что мы уже запустили этот оператор параметров, мы получили бы следующее с нашей xx:

> as.Date(chron(format(as.Date(xx, "%d%b%y"), "%m/%d/%y")))
[1] "2011-08-01" "2012-08-01" "1913-08-01"

2) Только дата .Вот альтернатива, которая не использует хрон.Вы можете заменить "2012-12-31" на Sys.Date(), если идея заключается в том, что в противном случае будущие даты действительно должны быть установлены на 100 лет назад:

d <- as.Date(xx, "%d%b%y")
as.Date(ifelse(d > "2012-12-31", format(d, "19%y-%m-%d"), format(d)))

РЕДАКТИРОВАТЬ: добавлено решение только для дат.

12 голосов
/ 19 сентября 2015

См. Ответ от связанной темы :

format(as.Date("65-05-14", "%y-%m-%d"), "19%y-%m-%d")
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...