#r #date #datetime #lubridate
Вопрос:
Предположим, у меня есть фрейм данных с двумя столбцами, один для месяцев, а второй для дней. Вот простой пример
month=c(2, 4, ,7, 8, 11, 11, 12)
day=c(21,4,6,8,15,20,30)
monthday=data.frame(month,day)
Я хочу определить число (от 1 до 365), которое соответствует дню года. Как я могу это сделать?
Ответ №1:
Вы можете использовать yday
функцию из lubridate
пакета:
library(dplyr)
library(tidyr)
library(lubridate)
month=c(2, 4,7, 8, 11, 11, 12)
day=c(21,4,6,8,15,20,30)
# also define a year so you can parse an actual date
year = 2021
monthday=tibble(month,day, year)
monthday %>%
# combine into one variable
tidyr::unite("date", year, month, day, sep = "-", remove = FALSE) %>%
# parse as date
dplyr::mutate(date = lubridate::ymd(date)) %>%
# extract day of year
dplyr::mutate(doy = lubridate::yday(date))
#> # A tibble: 7 x 5
#> date month day year doy
#> <date> <dbl> <dbl> <dbl> <dbl>
#> 1 2021-02-21 2 21 2021 52
#> 2 2021-04-04 4 4 2021 94
#> 3 2021-07-06 7 6 2021 187
#> 4 2021-08-08 8 8 2021 220
#> 5 2021-11-15 11 15 2021 319
#> 6 2021-11-20 11 20 2021 324
#> 7 2021-12-30 12 30 2021 364
Создано 2021-05-31 пакетом reprex (v2.0.0)
Ответ №2:
Сначала вам нужно указать год и преобразовать все "POSIXt"
. Тогда я рекомендую:
as.numeric(strftime(date, format = "%j"))