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 :

Mettre une macro variable entre parenthèses


Sujet :

Macro

  1. #1
    Membre du Club
    Femme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Novembre 2011
    Messages
    86
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2011
    Messages : 86
    Points : 48
    Points
    48
    Par défaut Mettre une macro variable entre parenthèses
    Bonjour,

    Je voudrais mettre une macro variable entre parenthèses, pour le faire,j'utilise la fonction cats, sauf que ca marche po. Merci d'avance pour votre aide.

    Voici le bout de code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    option mprint;
    proc sql; create table tes (ch char(1000));
    %macro gg;
    %let var=CD334+CD335+CD336+CD337;
    %let v=%SYSFUNC(COMPRESS(%sysfunc(cats('(',&var,')')),''''));
    proc sql;insert into tes values ("&v");
    %mend;
    %gg;

  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 : 47
    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
    Bonjour.
    Dans le langage macro, tout est du texte. Donc tu ajoutes tes parenthèses directement, sans fonction de concaténation.
    Tu peux aussi mettre les parenthèses directement là où elles sont nécessaires : dans ton exemple ça se ferait directement dans la commande INSERT.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO tes VALUES ("(&var)");
    Si tu as des espaces en trop dans tout ça, il y a la macro-fonction %CMPRES qui permet de les éliminer (elle fonctionne comme COMPBL).
    Bon courage.
    Olivier

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

Discussions similaires

  1. Utilisation d'une macro variable entre cotes
    Par magassama1986 dans le forum Macro
    Réponses: 4
    Dernier message: 13/05/2015, 12h33
  2. Réponses: 2
    Dernier message: 03/10/2013, 10h45
  3. Réponses: 2
    Dernier message: 22/03/2010, 15h26
  4. Réponses: 9
    Dernier message: 14/04/2008, 11h58
  5. [vector] Partager une même variable entre deux objets.
    Par Ekinoks dans le forum SL & STL
    Réponses: 18
    Dernier message: 25/08/2005, 20h40

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