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 :

Lignes d'une table en paramètres macro


Sujet :

Macro

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2012
    Messages : 15
    Points : 12
    Points
    12
    Par défaut Lignes d'une table en paramètres macro
    Bonjour tout le monde,

    C'est avec plaisir que je reviens sur ce fabuleux site

    Cette fois ci je demande de l'aide non pas en programmation VBA mais en programmation SAS.

    Je vous expose mon soucis :

    J'ai une macro du type : %macro test(parametre1 , parametre2 , parametre3)

    j'ai une table avec 3 variables qui correspondent à mes 3 paramètres.

    Je souhaiterai ma macro s’exécute autant de fois que j'ai de lignes de ma table en prenant en paramètre les valeurs de variables de chaque ligne.

    J'espère avoir été assez clair.

    Merci d'avance pour vos réponses.

  2. #2
    Membre expérimenté
    Homme Profil pro
    Attaché statisticien
    Inscrit en
    Mai 2011
    Messages
    687
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Attaché statisticien
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2011
    Messages : 687
    Points : 1 581
    Points
    1 581
    Par défaut
    Bonjour,

    Si ta macro génère un code de longueur variable, alors non tu n'as pas été suffisamment clair.

    Sinon
    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
     
    data parametres;
    input num_liste param1 param2 param3 ;
    datalines;
    1 4 5 6
    2 8 9 9
    3 1 2 3
    ;
    run;
     
    data les_freres_a_toto;
    input individus :$6. ;
    datalines ;
    toto
    titi
    tutu
    tautau
    ;
    run;
     
     
    %macro m(parametre1=,parametre2=,parametre3=);
    PUT &parametre1 = &parametre2= &parametre3 = ;
    %mend;
     
    data _null_;
    if 0 then set parametres;
    set les_freres_a_toto;
    if _n_=1 then 
    do;
    declare hash param(ordered:"y",dataset:"parametres");
    param.definekey("num_liste");
    param.definedata(all:'yes') ;
    param.definedone();
    declare hiter iparam('param');
    end;
     
    PUT individus= ;
     
    IRC=iparam.first();
    DO WHILE (IRC=0);
    %m(parametre1=param1,parametre2=param2,parametre3=param3);
    IRC=iparam.next();
    END;
    run;
    Bien sûr, avec des tables de test cela aurait été mieux.


    Bon courage à toi.

Discussions similaires

  1. Réponses: 8
    Dernier message: 01/10/2010, 10h52
  2. N° de ligne dans une table triée ?
    Par andremarco dans le forum Langage SQL
    Réponses: 6
    Dernier message: 24/06/2004, 17h19
  3. Réponses: 4
    Dernier message: 31/05/2004, 12h26
  4. determination le nombre de ligne d'une table
    Par picoti2 dans le forum Bases de données
    Réponses: 2
    Dernier message: 18/03/2004, 09h25
  5. Copier Coller une ligne d'une table avec modif ?
    Par nolan76 dans le forum Requêtes
    Réponses: 4
    Dernier message: 04/03/2004, 16h34

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