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 :

nom d'une colonne dans les paramètres


Sujet :

Macro

  1. #1
    Membre averti
    Femme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    272
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 272
    Points : 417
    Points
    417
    Par défaut nom d'une colonne dans les paramètres
    Bonjour,
    j'imagine que la question a déjà été posée, pourtant je ne trouve pas de traces dans les forums...
    Voici mon problème: j'essaie de créer une macro qui ajoute dans un tableau le résultat d'une régression linéaire sur des variables de ce tableau.
    Plus clairement, à partir du code suivant:
    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
    %macro CoeffRegLin(TableEnt,TableSort,y,x,reg);
     
    proc reg data=&TableEnt outest=&TableSort;
    	model &y=&x;
    run;
     
    /* Recuperation des coefficients*/
    data _NULL_;
    	set &TableSort;
    	CALL SYMPUT(COMPRESS('beta0'),intercept);
    	CALL SYMPUT(COMPRESS('beta1'),&x);
    run;
     
    /* Création de la variable reg */
    data &TableEnt;
    	set &TableEnt;
    	reg = &beta0+&beta1*&x;
    run;
     
    %mend;
    j'aimerais donner à "reg" le nom que je veux mais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    &reg = &beta0+&beta1*&x;
    ne marche évidemment pas.
    J'ai l'impression que c'est évident pourtant

    J'espère que quelqu'un aura la gentillesse de m'éclairer.
    Merci d'avance

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    72
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 72
    Points : 75
    Points
    75
    Par défaut
    Bonjour,

    Est-ce que tu as essayé quelque chose du style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    %let reg = %eval(&beta0+&beta1*&x);
    ?

  3. #3
    Rédacteur

    Homme Profil pro
    SAS ALLIANCE SILVER. Consultant et formateur SAS et Cognos.
    Inscrit en
    Avril 2009
    Messages
    2 497
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    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
    Points
    6 064
    Par défaut
    Chez moi ca marche. ce n'est pas ce que tu veux ?

    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
    %macro CoeffRegLin(TableEnt,TableSort,y,x,reg);
     
    proc reg DATA=&TableEnt outest=&TableSort;
    	model &y=&x;
    run;
     
    /* Recuperation des coefficients*/
    DATA _NULL_;
    	SET &TableSort;
    	CALL SYMPUT(COMPRESS('beta0'),intercept);
    	CALL SYMPUT(COMPRESS('beta1'),&x);
    run;
     
    /* Création de la variable reg */
    DATA houpla;
    	SET &TableEnt;
    	&reg = &beta0+&beta1*&x;
    run;
     
    %mend;
     
    %CoeffRegLin(sashelp.class,class,age,height,toto);

  4. #4
    Membre averti
    Femme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    272
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 272
    Points : 417
    Points
    417
    Par défaut cela ne marche pas chez moi
    Bonjour Datametric,
    merci pour ton code: effectivement, il tourne mais le mien:
    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
    %macro CoeffRegLin(TableEnt,TableSort,y,x,Sortie);
     
    proc reg data=&TableEnt outest=&TableSort;
    	model &y=&x;
    run;
     
    /* Recuperation des coefficients*/
    data _NULL_;
    	set &TableSort;
    	CALL SYMPUT(COMPRESS('beta0'),intercept);
    	CALL SYMPUT(COMPRESS('beta1'),&x);
    run;
     
    data &TableEnt;
    	set &TableEnt;
    	&reg = &beta0+&beta1*&x;
    run;
     
    %mend;
     
    %CoeffRegLin(series.tab1,series.ProfTemp,datemax, max, coeffreg);
    option spool;
    option symbolgen;
    me renvoie la log suivante
    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
    MPRINT(COEFFREGLIN):   data _NULL_;
    SYMBOLGEN :  Macro variable TABLESORT traitée dans series.ProfTemp
    MPRINT(COEFFREGLIN):   set series.ProfTemp;
    MPRINT(COEFFREGLIN):   CALL SYMPUT(COMPRESS('beta0'),intercept);
    SYMBOLGEN :  Macro variable X traitée dans max
    MPRINT(COEFFREGLIN):   CALL SYMPUT(COMPRESS('beta1'),max);
    MPRINT(COEFFREGLIN):   run;
     
    NOTE: Valeurs numériques converties en valeurs caractères aux emplacements indiqués par : (Ligne):(Colonne).
          1:137   1:1
    NOTE:  1 observation(s) lue(s) dans la table SERIES.PROFTEMP.
    NOTE: L'étape DATA a utilisé (Durée totale du traitement) :
          temps réel          0.01 secondes
          temps UC            0.01 secondes
     
     
    SYMBOLGEN :  Macro variable TABLEENT traitée dans series.tab1
    MPRINT(COEFFREGLIN):   data series.tab1;
    SYMBOLGEN :  Macro variable TABLEENT traitée dans series.tab1
    NOTE: Ligne générée par la macro appelée "COEFFREGLIN".
    1       proc reg data=&TableEnt outest=&TableSort;     model &y=&x; run;   data _NULL_;     set &TableSort;     CALL SYMPUT(COMPRESS('beta0'),intercept);     CALL
    1   ! SYMPUT(COMPRESS('beta1'),&x); run;  data &TableEnt;     set &TableEnt;     &reg = &beta0+&beta1*&x
                                                                                     -
                                                                                     180
    ERROR 180-322: Instruction incorrecte ou mal utilisée.
     
    MPRINT(COEFFREGLIN):   set series.tab1;
    WARNING: Référence symbolique apparente REG non traitée.
    SYMBOLGEN :  Macro variable BETA0 traitée dans -11469.49485
    SYMBOLGEN :  Macro variable BETA1 traitée dans 17.279735729
    SYMBOLGEN :  Macro variable X traitée dans max
    MPRINT(COEFFREGLIN):   &reg = -11469.49485+17.279735729*max;
    MPRINT(COEFFREGLIN):   run;
     
    NOTE: Le Système SAS a interrompu le traitement de cette étape en raison d'erreurs.
    WARNING: La table SERIES.TAB1 est peut-être incomplète.  Lorsque cette étape a été stoppée, il y avait 0 observation(s) et 14 variable(s).
    WARNING: Table SERIES.TAB1 non remplacée car cette étape a été interrompue.
    Je ne vois pas la différence, mis à part que la table que je manipule est un paramètre de la macro...
    Une idée svp?
    Encore merci

  5. #5
    Membre averti
    Femme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    272
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 272
    Points : 417
    Points
    417
    Par défaut
    Citation Envoyé par Petru16 Voir le message
    Bonjour,

    Est-ce que tu as essayé quelque chose du style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    %let reg = %eval(&beta0+&beta1*&x);
    ?
    Bonjour,
    j'ai essayé sans résultat
    Merci quand même

  6. #6
    Rédacteur

    Homme Profil pro
    SAS ALLIANCE SILVER. Consultant et formateur SAS et Cognos.
    Inscrit en
    Avril 2009
    Messages
    2 497
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    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
    Points
    6 064
    Par défaut
    lilly74, ce n'est pas le même code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    %macro CoeffRegLin(TableEnt,TableSort,y,x,Sortie);
    au lieu de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    %macro CoeffRegLin(TableEnt,TableSort,y,x,reg);
    donc tu obtiens :
    WARNING: Référence symbolique apparente REG non traitée.
    Pour le %let, c'est normal que cela ne fonctionne pas il doit chercher une valeur pour la variable &x.

  7. #7
    Membre averti
    Femme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    272
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 272
    Points : 417
    Points
    417
    Par défaut comment dire...
    Re-bonjour,
    je me sens toute bête là
    Merci

  8. #8
    Rédacteur

    Homme Profil pro
    SAS ALLIANCE SILVER. Consultant et formateur SAS et Cognos.
    Inscrit en
    Avril 2009
    Messages
    2 497
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    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
    Points
    6 064
    Par défaut
    A ton service

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

Discussions similaires

  1. Modification du nom d'une colonne dans une requete sql
    Par bivancha dans le forum Débuter
    Réponses: 1
    Dernier message: 02/12/2011, 10h41
  2. [XL-2007] Insérer une variable dans les paramètre d'un fonction
    Par anolo40 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 17/01/2011, 21h08
  3. SQL-Server changer le nom d'une colonne dans une table .
    Par silset dans le forum Développement
    Réponses: 2
    Dernier message: 31/10/2009, 23h34
  4. [RegEx] preg_replace : utiliser une fonction dans les paramètres
    Par Hell dans le forum Langage
    Réponses: 2
    Dernier message: 24/05/2008, 18h32
  5. [sql 2005]: changer le nom d'une colonne dans un table
    Par TheLittle dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 12/06/2006, 15h29

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