IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macro Discussion :

Affectation de macro-variables avec Call SymputX


Sujet :

Macro

  1. #1
    Membre éclairé Avatar de Filippo
    Homme Profil pro
    Statisticien
    Inscrit en
    Mai 2004
    Messages
    864
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Statisticien

    Informations forums :
    Inscription : Mai 2004
    Messages : 864
    Points : 881
    Points
    881
    Par défaut Affectation de macro-variables avec Call SymputX
    Bonsoir,
    à la première exécution du code suivant les macros-variables :
    &Annee, &Mois, &Periode, &FicOk et &Nom ne sont pas instanciées.

    A la seconde exécution (identique) du code : &Annee, &Mois, &Periode, &FicOk sont instanciées mais pas &FicOk.

    Il faut 3 exécutions du même code pour que le traitement fonctionne.

    Comment faire pour que le code marche à la première exécution ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    %Macro CreeTableMensuelle(MyTableRef, MyLibIn, MyTableOut, MyAnnee, MyMois, MyPeriode);
    	%Global PrefD;
    	%Global PrefC;
    	%Global PostRep;
     
    	%Global stRep;
    	%Global stFichier;
     
    	%Global Annee;
    	%Global Mois;
    	%Global Periode;
    	%Global FicOk;
     
    	%Global Nom;
     
     
    	/* Préfixe pour tables de données : Les tables s'appellent D_ suivi du nom du fichier d'origine */
    	%Let PrefD=D_;
     
    	/* Préfixe pour table de tests de contraintes */
    	%let prefC=C_;
     
    	/* PostFixe pour répertoire de tables à traiter (nom de la feuille de l'arborescence) */
    	%Let PostRep=A_TRAITER;
     
    	/* On parcourt la table MyTableRef */
    	Data _NULL_;
    		Set &MyTableRef;
    		/* Si l'enregistrement courant présente les bonnes condition alors on ajoute */
    		/* Le fichier qu'il désigne à MyTableOut */
    		Call SymputX('Annee',Annee);
    		Call SymputX('Mois',Mois);
    		Call SymputX('Periode',Periode);
    		Call SymputX('FicOk',FicOk);
     
    		%If &Annee eq &MyAnnee and &Mois eq &MyMois and &Periode eq &MyPeriode and &FicOk eq 1 %Then %Do;
     
    			/* Constitution du répertoire physique où se situe la table
    			/* des données à intégrer à la table mensuelle des données */
    			%If &MyPeriode eq A %Then %Let stRep=&MyLibIn.\&MyAnnee.\&MyMois.\ANNUEL;
    			%If &MyPeriode eq M %Then %Let stRep=&MyLibIn.\&MyAnnee.\&MyMois.\MENSUEL;
     
    			Libname LibSrc "&stRep.\&PostRep";
    			%put &stRep.\&PostRep;
     
    			/* Nom de la table à intégrer */
    			Call SymputX('Nom',Fichier);
    			%Let stFichier=&PrefD.&Nom;
    			%put MyTableRef = &MyTableRef - stFichier = &stFichier;
     
    			/* Ajout de la table à MyTableOut */
    			%IntegreTable(LibSrc.&StFichier,&MyTableOut);
     
     
    			/* Constitution du nom de la table des tests à intégrer à la table mensuelle des tests */
     
    		%End;
     
    	Run;
    %Mend;
    J'avais essayé au début en mettant des If à la place des %If sans utiliser de Call SymputX en comparant directement les valeurs de la table aux mactos-variables passées en paramètre mais je ne m'en sortais pas avec les %let.

    Si quelqu'un a une idée ça me dépannerait bien.

    Merci

  2. #2
    Rédacteur

    Homme Profil pro
    SAS ALLIANCE SILVER. Consultant et formateur SAS et Cognos.
    Inscrit en
    Avril 2009
    Messages
    2 497
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : SAS ALLIANCE SILVER. Consultant et formateur SAS et Cognos.
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2009
    Messages : 2 497
    Points : 6 064
    Points
    6 064
    Par défaut
    J'espère que ta table MyTableRef n'a qu'une ligne car tes call symputx ne traite qu'une, la dernière.
    Pourquoi mélanges-tu les %let et autres %if à une étape DATA ?
    Tu peux tout faire en étape data au niveau paramétrage.
    Ton RUN; est en bout de chaîne alors que je l'attendais après Call SymputX('FicOk',FicOk);

    Au mieux , tu peux utiliser les fonctions LIBREF et même faire un CALL EXECUTE pour appeler ta macro avec en paramètre les éléments de ton étape DATA _null_.

    Je pensais à quelque chose comme cela. Il faut supprimer le superflu si ca marche comme tu veux.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    %Macro CreeTableMensuelle(MyTableRef, MyLibIn, MyTableOut, MyAnnee, MyMois, MyPeriode);
    	%Global PrefD;
    	%Global PrefC;
    	%Global PostRep;
     
    	%Global stRep;
    	%Global stFichier;
     
    	%Global Annee;
    	%Global Mois;
    	%Global Periode;
    	%Global FicOk;
    	%Global Nom;
     
     
    	/* Préfixe pour tables de données : Les tables s'appellent D_ suivi du nom du fichier d'origine */
    	%Let PrefD=D_;
     
    	/* Préfixe pour table de tests de contraintes */
    	%let prefC=C_;
     
    	/* PostFixe pour répertoire de tables à traiter (nom de la feuille de l'arborescence) */
    	%Let PostRep=A_TRAITER;
     
    	/* On parcourt la table MyTableRef */
    DATA _NULL_;
    SET &MyTableRef;
    PrefD="D_";
    prefC="C_";
    MyLibIn=&MyLibIn;
    MyAnnee=&MyAnnee;
    MyMois=&MyMois;
    MyPeriode="&MyPeriode";
    MyTableOut="&MyTableOut";
     
    IF Annee eq MyAnnee AND Mois eq MyMois AND Periode eq MyPeriode AND FicOk eq 1 then do;
    if MyPeriode='A' then stRep=catx('\',&MyLibIn.,&MyAnnee.,&MyMois.,ANNUEL);
    if MyPeriode='M' then stRep=catx('\',&MyLibIn.,&MyAnnee.,&MyMois.,MENSUEL);
     
    rc=libname('LibSrc',stRep);
    stFichier=cats(PrefD,Fichier);
     
    CALL EXECUTE ('%IntegreTable(LibSrc.'||StFichier||MyTableOut||')');
    end;
    run;

  3. #3
    Membre éclairé Avatar de Filippo
    Homme Profil pro
    Statisticien
    Inscrit en
    Mai 2004
    Messages
    864
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Statisticien

    Informations forums :
    Inscription : Mai 2004
    Messages : 864
    Points : 881
    Points
    881
    Par défaut
    Merci Stéphane,
    ça me donne des idées.

    Ca coince au niveau de MyLibIn. Les : et \ ne plaisent pas à SAS; je ne sais pas si c'est à la compilation ou à l'exécution. J'essaie de jouer avec les fonctions http://support.sas.com/documentation...a001061345.htm

Discussions similaires

  1. utilisation variable avec Call
    Par DD339 dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 06/08/2009, 15h14
  2. [Macro] Libellé macro-variable avec proc sql
    Par auredura dans le forum Macro
    Réponses: 2
    Dernier message: 03/09/2008, 12h46
  3. [Macro] Macro variables avec condition
    Par bibette dans le forum Macro
    Réponses: 4
    Dernier message: 07/07/2008, 17h09
  4. Macro variable avec valeur contenant &
    Par Fatah93 dans le forum Macro
    Réponses: 2
    Dernier message: 19/05/2008, 15h11
  5. Utiliser les macro variables avec sql
    Par Euseibus dans le forum Macro
    Réponses: 5
    Dernier message: 25/10/2007, 18h40

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo