Macro SAS paramètre dans nom de fichier

[Résolu/Fermé]
Signaler
Messages postés
11
Date d'inscription
mercredi 23 janvier 2008
Statut
Membre
Dernière intervention
20 avril 2010
-
Messages postés
11
Date d'inscription
mercredi 23 janvier 2008
Statut
Membre
Dernière intervention
20 avril 2010
-
Bonjour,
une nouvelle fois j'ai besoin d'aide pour une macro :
%let an=07
%macro test;
%do jour= 01 %to 31;
%do mois= 01 %to 12;
data sd01;
set mabase&jour&mois&an;
where a='A';
run;
data sd;
set sd sd01;
run;
%end;
%end;
%mend;

%test;

les noms de mes fichiers sont du type mabase040507 j'ai essayé :

%let an=07
%macro test;
%do jour= 1 %to 9;
%do mois= 1 %to 9;
data sd01;
set mabase0&jour0&mois&an;
where a='A';
run;
data sd;
set sd sd01;
run;
%end;
%end;
%do jour= 10 %to 31;
%do mois= 10 %to 12;
data sd01;
set mabase&jour&mois&an;
where a='A';
run;
data sd;
set sd sd01;
run;
%end;
%end;
%mend;

%test;

Mais ça ne marche pas à cause du 0 entre &jour et &mois. Y-at-il un moyen de le forcer à mettre mon 0 ?
ou alors j'insère %let z='0' &jour&z&mois ?

Merci de l'aide que vous pourrez m'apporter.

Fabienne

2 réponses

Messages postés
277
Date d'inscription
lundi 12 mai 2003
Statut
Membre
Dernière intervention
22 octobre 2008
78
Bonjour,

Voici la solution :

remplacer set mabase&jour&mois&an;
par
set mabase%sysfunc(putn(&jour,z2.))%sysfunc(putn(&mois,z2.))&an;

on utilise ici le format z2. qui met un 0 devant si la valeur est sur 1 caractère. Pour appliquer le format dans une macro on utilise %sysfunc et putn qui applique le format à la volée.

Steel
Messages postés
11
Date d'inscription
mercredi 23 janvier 2008
Statut
Membre
Dernière intervention
20 avril 2010

Merci pour la réponse.


Du coup mon pg devient :
%let an=07
%macro test;
%do jour= 01 %to 31;
%do mois= 01 %to 12;
data sd01;
set mabase%sysfunc(putn(&jour,z2.))%sysfunc(putn(&mois,z2.))&an;
where a='A';
run;
data sd;
set sd sd01;
run;
%end;
%end;
%mend;

%test;