Como extrair o mês da data em r (com exemplos)


Existem duas maneiras de extrair rapidamente o mês de uma data em R:

Método 1: use formato()

 df$month <- format( as.Date (df$date, format=" %d/%m/%Y ")," %m ")

Método 2: Use o pacote de lubrificação

 library (lubridate)

df$month <- month( mdy (df$date))

Este tutorial mostra um exemplo de como usar cada um desses métodos na prática.

Método 1: extrair o mês da data usando format()

O código a seguir mostra como extrair o mês de uma data usando a função format() combinada com o argumento “%m” :

 #create data frame
df <- data. frame (date=c("01/01/2021", "01/04/2021" , "01/09/2021"),
                  sales=c(34, 36, 44))

#view data frame
df

        dirty date
1 01/01/2021 34
2 01/04/2021 36
3 01/09/2021 44

#create new variable that contains month
df$month <- format( as.Date (df$date, format=" %d/%m/%Y ")," %m ")

#view updated data frame
df

        date sales month
1 01/01/2021 34 01
2 01/04/2021 36 04
3 01/09/2021 44 09

Observe que esta função format() funciona com vários formatos de data. Você simplesmente precisa especificar o formato:

 #create data frame
df <- data. frame (date=c("2021-01-01", "2021-01-04", "2021-01-09"),
                  sales=c(34, 36, 44))

#view data frame
df

        dirty date
1 2021-01-01 34
2 2021-01-04 36
3 2021-01-09 44

#create new variable that contains month
df$month<- format( as.Date (df$date, format=" %Y-%m-%d ")," %m ")

#view updated data frame
df

        date sales month
1 2021-01-01 34 01
2 2021-01-04 36 01
3 2021-01-09 44 01

Nota : Você também pode usar %B para extrair o mês como um nome de string (janeiro) em vez de um valor numérico (01).

Método 2: Extrair mês a partir da data usando Lubridate

Também podemos usar funções no pacote lubridate para extrair rapidamente o mês de uma data:

 library (lubridate)

#create data frame
df <- data. frame (date=c("01/01/2021", "01/04/2021" , "01/09/2021"),
                  sales=c(34, 36, 44))

#view data frame
df

        dirty dates
1 01/01/2021 34
2 01/04/2021 36
3 01/09/2021 44

#create new variable that contains month
df$month<- month( mdy (df$date))

#view updated data frame
df

        date sales month
1 01/01/2021 34 1
2 01/04/2021 36 1
3 01/09/2021 44 1

Lubridate também funciona com uma variedade de formatos de data. Você simplesmente precisa especificar o formato:

 #create data frame
df <- data. frame (date=c("2021-01-01", "2021-01-04", "2021-01-09"),
                  sales=c(34, 36, 44))

#view data frame
df

        dirty date
1 2021-01-01 34
2 2021-01-04 36
3 2021-01-09 44

#create new variable that contains month
df$month <- month( ymd (df$date))

#view updated data frame
df

        date sales month
1 2021-01-01 34 1
2 2021-01-04 36 1
3 2021-01-09 44 1

Recursos adicionais

Os tutoriais a seguir explicam como realizar outras operações comuns em R:

Como extrair o ano da data em R
Como calcular o número de meses entre as datas em R

Add a Comment

O seu endereço de email não será publicado. Campos obrigatórios marcados com *