Personnaliser les préférences

Nous utilisons des cookies pour vous aider à naviguer efficacement et à exécuter certaines fonctions. Vous trouverez ci-dessous des informations détaillées sur tous les cookies sous chaque catégorie de consentement.

Les cookies classés comme « Nécessaires » sont stockés sur votre navigateur car ils sont essentiels pour activer les fonctionnalités de base du site.... 

Toujours actif

Necessary cookies are required to enable the basic features of this site, such as providing secure log-in or adjusting your consent preferences. These cookies do not store any personally identifiable data.

Aucun cookie à afficher.

Functional cookies help perform certain functionalities like sharing the content of the website on social media platforms, collecting feedback, and other third-party features.

Aucun cookie à afficher.

Analytical cookies are used to understand how visitors interact with the website. These cookies help provide information on metrics such as the number of visitors, bounce rate, traffic source, etc.

Aucun cookie à afficher.

Performance cookies are used to understand and analyze the key performance indexes of the website which helps in delivering a better user experience for the visitors.

Aucun cookie à afficher.

Advertisement cookies are used to provide visitors with customized advertisements based on the pages you visited previously and to analyze the effectiveness of the ad campaigns.

Aucun cookie à afficher.

Comment calculer les jours ouvrables dans R (avec des exemples)



Vous pouvez utiliser les fonctions du package bizdays dans R pour ajouter, soustraire et compter rapidement le nombre de jours ouvrables entre deux dates dans R.

Les exemples suivants montrent comment utiliser ces fonctions dans la pratique.

Exemple 1 : Compter le nombre de jours ouvrables entre deux dates dans R

Pour compter le nombre de jours ouvrés entre deux dates dans R, vous devez d’abord utiliser la fonction create.calendar() du package bizdays pour créer un calendrier contenant une liste de jours ouvrés :

library(bizdays)

#create business calendar
business_calendar <- create.calendar('my_calendar', weekdays = c('saturday','sunday'))

Notez que l’argument weekdays spécifie quels jours de la semaine ne sont pas des jours ouvrables.

On peut alors utiliser la fonction bizdays() pour compter le nombre de jours ouvrés entre deux dates précises :

library(bizdays)

#calculate number of business days between two dates
bizdays(from = '2022-01-01', to = '2022-12-31', cal = business_calendar)

[1] 259

D’après le résultat, nous pouvons voir qu’il y a 259 jours ouvrables entre le 01/01/2022 et le 31/12/2022.

Exemple 2 : ajouter et soustraire des jours ouvrables à la date dans R

Supposons que nous disposions du bloc de données suivant dans R qui contient des informations sur les ventes totales réalisées dans un magasin à différentes dates :

#make this example reproducible
set.seed(1)

#create data frame
df <- data.frame(date = as.Date('2022-01-01') + 0:249,
                 sales = runif(n=250, min=1, max=30))

#view head of data frame
head(df)

        date     sales
1 2022-01-01  8.699751
2 2022-01-02 11.791593
3 2022-01-03 17.612748
4 2022-01-04 27.338026
5 2022-01-05  6.848776
6 2022-01-06 27.053301

Nous pouvons utiliser la fonction offset() du package bizdays pour ajouter 10 jours ouvrables à chaque date :

library(bizdays) 

#create business calendar
business_calendar <- create.calendar('my_calendar', weekdays = c('saturday','sunday'))

#add 10 business days to each date
df$date <- bizdays::offset(df$date, 10, cal = business_calendar)

#view updated head of data frame
head(df)

        date     sales
1 2022-01-14  8.699751
2 2022-01-14 11.791593
3 2022-01-17 17.612748
4 2022-01-18 27.338026
5 2022-01-19  6.848776
6 2022-01-20 27.053301

Notez que 10 jours ouvrables ont été ajoutés à chaque date.

Pour soustraire des jours ouvrables, utilisez simplement un nombre négatif dans la fonction offset() .

Par exemple, le code suivant montre comment soustraire 10 jours ouvrables à chaque date :

library(bizdays) 

#create business calendar
business_calendar <- create.calendar('my_calendar', weekdays = c('saturday','sunday'))

#subtract 10 business days to each date
df$date <- bizdays::offset(df$date, -10, cal = business_calendar)

#view updated head of data frame
head(df)

        date     sales
1 2021-12-20  8.699751
2 2021-12-20 11.791593
3 2021-12-20 17.612748
4 2021-12-21 27.338026
5 2021-12-22  6.848776
6 2021-12-23 27.053301

Notez que 10 jours ouvrables ont été soustraits à chaque date.

Remarque : Vous pouvez trouver la documentation complète du package bizdays ici .

Ressources additionnelles

Les didacticiels suivants expliquent comment effectuer d’autres tâches courantes dans R :

Comment convertir une date en numérique dans R
Comment extraire le mois de la date dans R
Comment ajouter et soustraire des mois à une date dans R

Ajouter un commentaire

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *