Temukan hari dalam seminggu

215

Katakanlah saya punya kencan di R dan diformat sebagai berikut.

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

Apakah ada cara di R untuk menambahkan kolom lain dengan hari dalam seminggu terkait dengan tanggal? Dataset benar-benar besar, jadi tidak masuk akal untuk secara manual dan melakukan perubahan.

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

Jadi setelah menambahkan hari, itu akan berakhir seperti:

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

Apakah ini mungkin? Adakah yang bisa mengarahkan saya ke sebuah paket yang akan memungkinkan saya melakukan ini? Hanya berusaha menghasilkan hari secara otomatis berdasarkan tanggal.

ATMathew
sumber

Jawaban:

297
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

Edit: Hanya untuk menunjukkan cara lain ...

The wdaykomponen dari suatu POSIXltobjek adalah hari kerja numerik (0-6 awal pada hari Minggu).

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

yang bisa Anda gunakan untuk mengelompokkan vektor karakter dari nama hari kerja

c("Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", 
    "Friday", "Saturday")[as.POSIXlt(df$date)$wday + 1]
## [1] "Wednesday" "Wednesday" "Thursday" 
GSee
sumber
3
+1 Apakah ada cara yang digunakan weekdaysuntuk mendapatkan jumlah hari kerja seperti yang Anda lakukan as.POSIXlt??
Shambho
3
@Shambho Saya kira Anda bisa melakukan ini: setNames(0:6, c("Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"))[weekdays(as.Date(df$date))]. Jika Anda tidak suka namanya, Anda bisa membungkusnya unname().
GSee
6
Untuk mendapatkan nomor hari kerja (0-6, Minggu) dari tanggal yang dapat Anda lakukan: format (as.Date (df $ date), "% w"). Untuk perincian kode format, lihat stat.berkeley.edu/~s133/dates.html
JStrahl
65

Lihat ke atas ?strftime:

%A Nama hari kerja lengkap di lokasi saat ini

df$day = strftime(df$date,'%A')
memotret
sumber
15
Jika seseorang mencari nomor hari kerja - gunakan '%u'sebagai ganti'%A'
Vlad Holubiev
64

Gunakan lubridatepaket dan fungsi 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
Andrie
sumber
11
Hal yang baik tentang pendekatan ini adalah ia mengembalikan hari sebagai faktor, jadi jika Anda membuat bagan hari-hari akan berada dalam urutan yang benar.
bobfet1
Untuk mendapatkan kata lengkap untuk setiap hari (mis. Minggu, bukan Sun):abbr = FALSE
stevec
17

Katakanlah Anda juga ingin minggu ini dimulai pada hari Senin (bukan default pada hari Minggu), maka yang berikut ini sangat membantu:

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

Hasilnya adalah hari-hari dalam interval [0, .., 6].

Jika Anda ingin intervalnya menjadi [1, .. 7], gunakan yang berikut ini:

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

... atau, sebagai alternatif:

df$day = df$day + 1
Peter Lustig
sumber
5
Anda juga dapat menggunakan argumen week_start:wday(df$date, label = TRUE, week_start = 1)
mrub
12

Ini harus melakukan trik

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
Tyler Rinker
sumber
6
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
s_scolary
sumber
3

dari komentar JStrahl format(as.Date(df$date),"%w"), kami mendapatkan jumlah hari ini: as.numeric(format(as.Date("2016-05-09"),"%w"))

Qbik
sumber