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 :

Boucle macro SAS


Sujet :

Macro

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2011
    Messages
    37
    Points
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 37
    Points : 15
    Par défaut Boucle macro SAS
    Bonjour ,

    Alors j'ai une question qui peut être n'a pas de solution...

    J'ai crée une macro sas permettant de faire des graphiques: ci dessous

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    %Macro Analyse_fides (table=,  var1=,  var2=,);
    proc gchart data= &table; 
    vbar &var1 / subgroup = &var2; 
    run;
    quit;
    %MEND ;
     
    %Analyse_fides (table=fides.Fides , var1= Fid_FicStruct2 , var2= Type_); 
    %Analyse_fides (table=fides.Fides , var1= Fid_FicStruct_Prev , var2= Type_);

    Le problème est que j'ai beaucoup d'autres variables et je me demandais si il était possible de faire une boucle.
    Si oui, je ne vois pas bien comment la réaliser =(

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

  2. #2
    Membre expérimenté
    Avatar de MEGAMIND2
    Homme Profil pro
    Paris
    Inscrit en
    Janvier 2011
    Messages
    1 029
    Points
    1 489
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Paris

    Informations forums :
    Inscription : Janvier 2011
    Messages : 1 029
    Points : 1 489
    Par défaut
    Bonjour,
    Ce que tu veux ressemble à quelque chose comme ça:

    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
    PROC CONTENTS DATA=SASHELP.CLASS OUT=CLASS(WHERE=(TYPE=1));
    RUN;
     
    DATA _NULL_;
    set CLASS;
    CALL SYMPUT("var"!!LEFT(_N_),NAME);
    CALL SYMPUT("loop",_N_);
    RUN;
     
    %PUT &var1;
    %PUT &var2;
    %PUT &var3;
    %PUT &loop.;
     
    %MACRO Analyse_fides (table=, var2=);
     
    %DO i=1 %TO &loop.;
    	proc gchart data= &table;
    	vbar &&var&i. / subgroup = &var2.;
    	run;
    	quit;
    %END;
    %MEND Analyse_fides ;
    %Analyse_fides (table=SASHELP.CLASS,  var2=Sex);
    Bon courage!

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2011
    Messages
    37
    Points
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 37
    Points : 15
    Par défaut
    Merci pour cette réponse aussi rapide !

    Est ce que ca vous dérangerai de mettre des commentaires pour que je comprenne un peu plus ce qui se passe et à quel moment.
    Je n'ai encore jamais fait de boucle sur sas et j'ai un peu de mal à comprendre.

    Merci encore ^^

  4. #4
    Rédacteur

    Homme Profil pro
    SAS ALLIANCE SILVER. Consultant et formateur SAS et Cognos.
    Inscrit en
    Avril 2009
    Messages
    2 497
    Points
    6 064
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    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
    Par défaut
    tiens si tu veux voir une boucle plus petite, entraîne toi avec une boucle autour des %PUT de Brice.

    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
    %PUT &var1;
    %PUT &var2;
    %PUT &var3; 
    
    Devient :
    
    %macro tourneenrond;
    
    %do i = 1 %to %loop;
    
    %put &&var&i ;
    
    %end;
    
    %mend ;
    
    %tourneenrond;
    Le & en bleu est nécessaire pour résoudre &var1 après que &i soit résolu.

  5. #5
    Membre expérimenté
    Avatar de MEGAMIND2
    Homme Profil pro
    Paris
    Inscrit en
    Janvier 2011
    Messages
    1 029
    Points
    1 489
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Paris

    Informations forums :
    Inscription : Janvier 2011
    Messages : 1 029
    Points : 1 489
    Par défaut
    Voici une version documentée

    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
    %MACRO ANALYSE_FIDES(TABLE=, type_=); 
     
    	PROC CONTENTS DATA=&TABLE. OUT=CLASS(WHERE=(TYPE=1));/* on ne garde que des variables continues (type=1)*/
    	RUN; 
     
    	DATA _NULL_;
    	SET CLASS END=EOF                  ;/* on se positionne à la dernière ligne de la table */
    	CALL SYMPUT("var"!!LEFT(_N_),NAME) ;/* on stock chaque variable dans une macro ( _N_=compteur du nombre de  ligne)*/
    	IF EOF THEN CALL SYMPUT("loop",_N_);/* si on est en fin de fichier alors loop=dernier _N_ */
    	RUN;
     
    	%DO i=1 %TO &loop.;
     
    	 %PUT var&i.=&&var&i.; /* afficher dans l'output*/
    		proc gchart DATA= &table;
    		vbar &&var&i. / subgroup = &var2.;/* pour i=1 &&var&i=var1=Age*/
    		run;
    		quit;	
    	%END;
     
    %MEND ANALYSE_FIDES ;
     
    %ANALYSE_FIDES(TABLE=SASHELP.CLASS,  type_=Sex);
     
     
    /*  si jamais t'as pas compris SAS gère le compeur _N_, voici un exemple*/
    DATA test;
    input s;
    compteur=_N_;/*  < =====*/
    cards;
    78
    45
    12
    36
    ;
    run;

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2011
    Messages
    37
    Points
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 37
    Points : 15
    Par défaut
    Merci pour ces infos supplémentaires !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Macro SAS: boucles de PROC's
    Par Lameth dans le forum Macro
    Réponses: 9
    Dernier message: 14/09/2009, 18h00
  2. [Macro] procedures ou Macros sas SVM
    Par cyberboy00 dans le forum Macro
    Réponses: 9
    Dernier message: 11/07/2008, 10h35
  3. Boucle dans macro SAS avec BY
    Par fafabzh6 dans le forum Macro
    Réponses: 5
    Dernier message: 17/06/2008, 13h08
  4. macro sas problème
    Par floflorette56 dans le forum Macro
    Réponses: 2
    Dernier message: 21/04/2008, 14h11
  5. exécution de Macro SAS
    Par CélineM dans le forum Macro
    Réponses: 2
    Dernier message: 02/04/2008, 16h06

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