Найди день недели - PullRequest
       44

Найди день недели

194 голосов
/ 09 февраля 2012

Допустим, у меня есть дата в R, и она отформатирована следующим образом.

   date      
2012-02-01 
2012-02-01
2012-02-02

Можно ли в R добавить еще один столбец с днем ​​недели, связанным с датой?Набор данных действительно большой, поэтому нет смысла проходить вручную и вносить изменения.

df = data.frame(date=c("2012-02-01", "2012-02-01", "2012-02-02")) 

Так что после добавления дней он будет выглядеть примерно так:

   date       day
2012-02-01   Wednesday
2012-02-01   Wednesday
2012-02-02   Thursday

Возможно ли это?Может кто-нибудь указать мне пакет, который позволит мне сделать это?Просто пытаюсь автоматически сгенерировать день по дате.

Ответы [ 7 ]

273 голосов
/ 09 февраля 2012
df = data.frame(date=c("2012-02-01", "2012-02-01", "2012-02-02")) 
df$day <- weekdays(as.Date(df$date))
df
##         date       day
## 1 2012-02-01 Wednesday
## 2 2012-02-01 Wednesday
## 3 2012-02-02  Thursday

Редактировать: Просто чтобы показать другой путь ...

Компонент wday объекта POSIXlt - это числовой день недели (0-6, начиная с воскресенья).

as.POSIXlt(df$date)$wday
## [1] 3 3 4

, который можно использовать для подстановки вектора символов имен дней недели

c("Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", 
    "Friday", "Saturday")[as.POSIXlt(df$date)$wday + 1]
## [1] "Wednesday" "Wednesday" "Thursday" 
61 голосов
/ 09 февраля 2012

Поиск ?strftime:

%A Полное название дня недели в текущей локали

df$day = strftime(df$date,'%A')
50 голосов
/ 09 февраля 2012

Используйте пакет lubridate и функцию wday:

library(lubridate)
df$date <- as.Date(df$date)
wday(df$date, label=TRUE)
[1] Wed   Wed   Thurs
Levels: Sun < Mon < Tues < Wed < Thurs < Fri < Sat
17 голосов
/ 21 марта 2014

Допустим, вы хотите, чтобы неделя начиналась с Понедельник (вместо значения по умолчанию в воскресенье), тогда полезно следующее:

require(lubridate)
df$day = ifelse(wday(df$time)==1,6,wday(df$time)-2)

Результатом являются дни винтервал [0, .., 6].

Если вы хотите, чтобы интервал был [1, .. 7], используйте следующее:

df$day = ifelse(wday(df$time)==1,7,wday(df$time)-1)

... или, альтернативно:

df$day = df$day + 1
12 голосов
/ 09 февраля 2012

Это должно сработать

df = data.frame(date=c("2012-02-01", "2012-02-01", "2012-02-02")) 
dow <- function(x) format(as.Date(x), "%A")
df$day <- dow(df$date)
df

#Returns:
        date       day
1 2012-02-01 Wednesday
2 2012-02-01 Wednesday
3 2012-02-02  Thursday
4 голосов
/ 28 сентября 2017
start = as.POSIXct("2017-09-01")
end = as.POSIXct("2017-09-06")

dat = data.frame(Date = seq.POSIXt(from = start,
                                   to = end,
                                   by = "DSTday"))

# see ?strptime for details of formats you can extract

# day of the week as numeric (Monday is 1)
dat$weekday1 = as.numeric(format(dat$Date, format = "%u"))

# abbreviated weekday name
dat$weekday2 = format(dat$Date, format = "%a")

# full weekday name
dat$weekday3 = format(dat$Date, format = "%A")

dat
# returns
    Date       weekday1 weekday2  weekday3
1 2017-09-01        5      Fri    Friday
2 2017-09-02        6      Sat    Saturday
3 2017-09-03        7      Sun    Sunday
4 2017-09-04        1      Mon    Monday
5 2017-09-05        2      Tue    Tuesday
6 2017-09-06        3      Wed    Wednesday
3 голосов
/ 09 мая 2016

из комментария JStrahl format(as.Date(df$date),"%w") мы получаем номер текущего дня: as.numeric(format(as.Date("2016-05-09"),"%w"))

...