Comment convertir DateHeure en date dans SAS
Le moyen le plus simple de convertir une date/heure en date dans SAS consiste à utiliser la fonction DATEPART .
Cette fonction utilise la syntaxe de base suivante :
date = put(datepart(some_datetime), mmddyy10.);
L’argument mmddyy10. spécifie que la date doit être au format 15/10/2022.
L’exemple suivant montre comment utiliser cette syntaxe dans la pratique.
Exemple : convertir Datetime en Date dans SAS
Supposons que nous ayons l’ensemble de données suivant dans SAS qui contient une colonne de dates et d’heures :
/*create dataset*/
data original_data;
format some_datetime datetime23.;
input some_datetime :datetime23.;
datalines;
14OCT2022:0:0:0
09NOV2022:0:0:0
14NOV2022:0:0:0
15NOV2022:0:0:0
22DEC2022:0:0:0
24DEC2022:0:0:0
04JAN2023:0:0:0
;
run;
/*view dataset*/
proc print data=original_data;
Le code suivant montre comment utiliser la fonction DATEPART pour créer un nouvel ensemble de données dans lequel les valeurs de la colonne datetime sont formatées sous forme de dates avec différents formats :
/*create new dataset with datetime formatted as date*/
data new_data;
set original_data;
date_mmddyyyy = put(datepart(some_datetime), mmddyy10.);
date_yyyymmdd = put(datepart(some_datetime), yymmdd10.);
date_date9 = put(datepart(some_datetime), date9.);
date_default = datepart(some_datetime);
run;
/*view new dataset*/
proc print data=new_data;
Notez que les quatre nouvelles colonnes affichent la date de la colonne datetime d’origine dans différents formats.
Par défaut, la fonction DATEPART convertit une date/heure en nombre de jours depuis le 1er janvier 1960.
Ainsi, la nouvelle colonne appelée date_default affiche le nombre de jours depuis le 1er janvier 1960 pour chaque datetime.
Remarque : Vous pouvez trouver la documentation complète de la fonction SAS DATEPART ici .
Ressources additionnelles
Les didacticiels suivants expliquent comment effectuer d’autres tâches courantes dans SAS :
Comment ajouter des jours à ce jour dans SAS
Comment convertir une variable numérique en date dans SAS
Comment calculer la différence entre deux dates dans SAS