Как преобразовать числовое значение в значение даты - PullRequest
3 голосов
/ 12 апреля 2019

Итак, у меня есть data.frame со столбцом с именем Date.birth, но у меня есть эти значения в числовом формате:

Date.birth
43067
43060

Возможно, это проблемный формат. Но мне нужно в формате даты, как эти:

Date.birth
11/28/17
11/21/17

На самом деле приведенный выше формат является правильным. Я попробовал эту команду:

as.Date(levels(data$Date.birth), format="%d.%m.%Y")

но не сработало. У кого-нибудь есть предложение?

Спасибо.

Ответы [ 4 ]

3 голосов
/ 12 апреля 2019

Если это числовая дата в формате Excel, janitor предлагает отличное решение:

library(janitor)

excel_numeric_to_date(data$Date.birth)
3 голосов
/ 12 апреля 2019

Нам нужно указать источник, если это numeric значение

as.Date(data$Date.birth, origin = "1899-12-30")

например,

as.Date(43067, origin = "1899-12-30")
#[1] "2017-11-28"

После преобразования в класс Date, если оно должно быть впользовательский формат, используйте format

format(as.Date(43067, origin = "1899-12-30"), "%m/%d/%y")
#[1] "11/28/17"
2 голосов
/ 12 апреля 2019

Это можно сделать просто с помощью lubridate package-

lubridate::as_date(as.numeric(dt$Date.birth),origin="1899-12-30")  
[1] "2017-11-28" "2017-11-21"

Sample Data-

dt <- read.table(text="Date.birth
43067
43060",header=T)
1 голос
/ 22 апреля 2019

попробуйте

VariableName <- dt %>% 
mutate(Date.birth = format(excel_numeric_to_date(as.numeric(Date.birth)),"%m/%d/%y"))
#[1] "11/28/17"
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...