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] Question concernant l'utilisation du CALL symput


Sujet :

Macro

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    526
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 526
    Points : 224
    Points
    224
    Par défaut [Macro] Question concernant l'utilisation du CALL symput
    Salut,

    J'aurai une question concernant l'utilisation de la fonction CALL SYMPUT:

    Lorsque je crées des macro variables avec un CALL SYMPUT par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    data _NULL_;
    set courb.tableintermediaire;
    CALL SYMPUT(COMPRESS("numclasseanc"||_N_),numclasse);
    CALL SYMPUT(COMPRESS("numclassenouv"||_N_),numclassenouv);
    run;
    Si je veux les utiliser directement comme cela , cela provoque une erreur:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    data courb.previsioncourante;
    set courb.previsioncourante;
     
    %do i=1 %to &nombreclasse.;
     
    prev&&NUMCLASSENOUV&i.=prevision_client&&NUMCLASSEANC&i.;
    drop  prevision_client&&NUMCLASSEANC&i.;
     
    %end;
    run;

    Je suis obliger de redéclarer des macro variables intermédiaires à l'intérieur de l'étape DATA comme cela pour que ça marche et je voulais savoir pourquoi?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    data courb.previsioncourante;
    set courb.previsioncourante;
     
    %do i=1 %to &nombreclasse.;
     
    %let indi=&&NUMCLASSEANC&i.;
    %let ind2i=&&NUMCLASSENOUV&i.;
     
    prev&ind2i.=prevision_client&indi.;
    drop  prevision_client&indi.;
     
    %end;
    run;
    Merci.

  2. #2
    Expert confirmé
    Avatar de olivier.decourt
    Homme Profil pro
    Formateur R/SAS/statistiques
    Inscrit en
    Avril 2008
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Activité : Formateur R/SAS/statistiques
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 064
    Points : 4 478
    Points
    4 478
    Par défaut
    Quand tu dis, "des erreurs", lesquelles ?
    Les éléments de macro-langage comme les boucles %DO ne sont pas influencées par leur emplacement dans un programme : elles sont exécutées avant. La boucle n'est donc pas spécialement dans l'étape Data. Il y a donc quelque chose de curieux ici.
    Au hasard : ça ne serait pas des espaces à gauche dans les valeurs ? Qui s'incrusteraient ensuite, pour faire PREV 2 par exemple là où tu voudrais PREV2 ?
    Si c'est ça, deux solutions : en v9, CALL SYMPUTX au lieu de CALL SYMPUT ; en v8, ajouter un COMPRESS ou un LEFT autour du 2e argument du CALL SYMPUT.

    Olivier
    Bon courage.
    Olivier

  3. #3
    Membre émérite

    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mars 2005
    Messages
    1 364
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Conseil

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 364
    Points : 2 329
    Points
    2 329
    Par défaut
    Tes variables sont bien créées, tu peux le vérifier en utilisanat un
    fais le test de cette manière
    Quand tu utilises une maco variable tu fais tuojours un %let avant il me semble
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    data courb.previsioncourante;
    set courb.previsioncourante;
     
    %do i=1 %to &nombreclasse.;
     
    %let   prev&&NUMCLASSENOUV&i.=prevision_client&&NUMCLASSEANC&i.;
           drop prevision_client&&NUMCLASSEANC&i.;
     
    %end;
    run;
    Consultez les FAQs et les anciens postes avant de poser vos questions. Merci

  4. #4
    Responsable SAS


    Inscrit en
    Septembre 2006
    Messages
    3 176
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 3 176
    Points : 16 219
    Points
    16 219
    Par défaut
    Salut,
    Tes macros variables ici font-elles références à des variables au sens base de données?
    Les balises code
    FAQ SAS
    Rubrique SAS

    Si vous souhaitez contribuer à la rubrique SAS, contactez-moi ou tout autre membre de l'équipe BI par MP.

  5. #5
    Membre actif
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    526
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 526
    Points : 224
    Points
    224
    Par défaut
    J'ai essayé et en rajoutant un compress sur la deuxième variable,ça marche.
    C'était bien un pb d'espace.

    Merci.

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

Discussions similaires

  1. Utilisation de call symput
    Par Heisenberg59 dans le forum Macro
    Réponses: 2
    Dernier message: 22/08/2012, 15h50
  2. Réponses: 3
    Dernier message: 16/04/2009, 23h01
  3. utilisation du call symput
    Par mioke dans le forum Macro
    Réponses: 14
    Dernier message: 13/05/2008, 11h42
  4. [MySQL] Petite question concernant la notation utilisée dans une requête
    Par jlb59 dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 31/01/2008, 09h40
  5. Questions concernant l'utilisation des ComboBox
    Par philguio dans le forum Windows Forms
    Réponses: 2
    Dernier message: 09/01/2007, 11h26

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