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 :

Macro avec deux boucles %do


Sujet :

Macro

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 2
    Points : 2
    Points
    2
    Par défaut Macro avec deux boucles %do
    Bonjour à tous et merci d'avance à ceux qui prendront le temps de me lire ;-)

    Je commence à m'initier aux macros sur SAS (je suis encore novice en la matière). J'essaie de m'autoformer comme je peux mais là je me retrouve face à une difficulté que je n'arrive pas à surmonter.

    Pour ce qui est du contexte, je dispose d'une table regroupant les caractéristiques d'une population hétérogène. Je m'intéresse à une variable (Type) mesurée à 4 âges différents: à 25 ans, à 40ans, à 50 ans et à 60 ans. A partir de la base originale, j'ai crée une nouvelle base (à l'aide d'une macro) avec les identifiants des sujets dans la 1ère colonne et les années croissantes pour les autres colonnes (de l'année des 25 ans du plus vieux sujet à la date de fin du recueil):

    ID - Type1950 - Type1951 - Type1953 - .... - Type2009 - Type2010
    1
    2
    3
    ...

    Pour chaque sujet, j'ai assigné la valeur de la variable aux 4 ages aux années correspondantes, ce qui fait que j'ai désormais au maximum 4 observations par lignes (et des cases vides pour les autres années).

    Je souhaiterais créer une macro qui me permette de répondre à la condition suivante: si la variable pour l'année des 25 ans = variable pour l'année des 40 ans, alors attribuer la même valeur à l'année des 26, 27,...,38 et 39 ans.

    J'ai tenté de créer une 1ère macro mais hélas sans succès:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    %macro create2540(table);
    %local i;
    %do i=1950 %to 2010 %by 1;
    data &table;
    set &table;
    %if Type&i ne . and Type&i=Type(&i+15) %then Type(&i+1)=Type(&i+2)=Type(&i+3)=Type(&i+4)=Type(&i+5)=Type(&i+6)=Type(&i+7)=Type(&i+8)=Type(&i+9)=Type(&i+10)=Type(&i+11)=Type(&i+12)=Type(&i+13)=Type(&i+14)=Type&i;
    run;
    %end;
    %mend create2540;
    J'imagine que ce sont les passages entre parenthèse qui ne sont pas tolérés...

    L'autre option que j'envisageais était de faire une macro avec une double boucle mais je me retrouve confronté au même problème (= à la même erreur):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    %macro create2540(table);
    %local i j;
    %do i=1950 %to 2010 %by 1;
    %do j=1 %to 14 %by 1;
    data &table;
    set &table;
    %if Type&i ne . and Type&i=Type(&i+15) %then Type(&i+&j)=Type&i;
    run;
    %end;
    %mend create2540;
    Est-ce que je suis complètement à côté de la plaque?

    Merci!

  2. #2
    Membre éprouvé
    Avatar de m.brahim
    Homme Profil pro
    SAS / BIG DATA
    Inscrit en
    Juillet 2011
    Messages
    461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : SAS / BIG DATA
    Secteur : Conseil

    Informations forums :
    Inscription : Juillet 2011
    Messages : 461
    Points : 1 119
    Points
    1 119
    Billets dans le blog
    14
    Par défaut
    Bonjour,

    Je te propose cette solution:
    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
     
    data test;
    input id y1950-y1960;
    cards;
    1 10 . . . . . 10 45 71 8 4
    1 5 . . . . . 10 . . 8 4
    1 1 . . . 4 . . . . 2 4
    1 . . 15 . . . . . 15 8 4
    1 . 10 . . . . . 10 71 . 4
    1 8 . 4 . . . . . . 4 7
    ;
    run;
     
    data test1(drop=i rc);
    set test;
    array y(*) y:;
    do i =1 to dim(y)-6;
    if y(i) ne .  and y(i)=y(i+6) then do ;
    rc=i;
    do i=rc to rc+5;
    y(i+1)=y(i);
    end;
    end;
    end;
    run;
    Cordialement
    Certification des Talents de la programmation In Memory Statistics sur HADOOP:
    http://talents-imstat.groupe-avisia....avance?uid=162

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Merci beaucoup pour ta réponse.
    Mon niveau en SAS étant encore limité, est-ce que tu pourrais m'expliquer les différentes étapes de ton programme?
    Désolé de faire mon boulet...

  4. #4
    Membre éprouvé
    Avatar de m.brahim
    Homme Profil pro
    SAS / BIG DATA
    Inscrit en
    Juillet 2011
    Messages
    461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : SAS / BIG DATA
    Secteur : Conseil

    Informations forums :
    Inscription : Juillet 2011
    Messages : 461
    Points : 1 119
    Points
    1 119
    Billets dans le blog
    14
    Par défaut
    Bonjour,

    L'instruction array permets de réaliser un traitement groupé sur un ensemble de colonnes sélectionnées.
    Pour ce sujet, voici les étapes de traitement :
    1/ grouper les colonnes à traiter :2/ une fois cette condition est réalisée :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if y(i) ne .  and y(i)=y(i+6) then do ;
    3/ Je récupère la position de la première colonne :4/ J'affecte la valeur de la première colonne aux colonnes suivantes:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    do i=rc to rc+5; y(i+1)=y(i);
    Si tu as d'autres questions n'hésiter pas

    Cordialement
    Certification des Talents de la programmation In Memory Statistics sur HADOOP:
    http://talents-imstat.groupe-avisia....avance?uid=162

  5. #5
    Candidat au Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Merci beaucoup!

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

Discussions similaires

  1. Macro avec plusieurs boucles
    Par m.hamdouch dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/05/2012, 11h31
  2. Problème avec deux boucles
    Par Akim13 dans le forum Langage
    Réponses: 2
    Dernier message: 03/11/2011, 05h12
  3. Problème avec deux boucles do whiles imbriquées
    Par breizh297 dans le forum Fortran
    Réponses: 1
    Dernier message: 15/11/2010, 08h37
  4. Réponses: 22
    Dernier message: 20/05/2008, 10h25
  5. Réponses: 3
    Dernier message: 24/05/2007, 17h56

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