Précédent   Forum des professionnels en informatique > Logiciels > Solutions d'entreprise > Business Intelligence > SAS > Macro
Macro Forum d'entraide sur le langage Macro de SAS
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 25/06/2008, 12h28   #1
Invité régulier
 
Étudiant
Inscription : mai 2008
Messages : 18
Détails du profil
Informations personnelles :
Âge : 23

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : mai 2008
Messages : 18
Points : 7
Points : 7
Envoyer un message via MSN à l'breton du 29
Par défaut Utilisation macro variable

salut,

En SAS/AF comment appel t on des variables créées dans un bloc submit continue??
faut il mettre le nom de la variable précédé d'un & ou non??

Merci.
++
l'breton du 29 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/06/2008, 14h34   #2
Membre Expert
 
Inscription : mars 2005
Messages : 1 028
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 1 028
Points : 1 278
Points : 1 278
Envoyer un message via Yahoo à bahraoui
Par défaut Utilisation macro variable

Citation:
Envoyé par l'breton du 29 Voir le message
comment fait on pour obtenir le résultat d'un calcul entre plusieurs variables dans une variable.
par exemple je veux que la variable r soit égale au résultat du calcul b+c*e/g
ou b, c, e et g sont des variables obtenus précédement.
calcul dans une étape data ou dans une maco?
bahraoui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/06/2008, 16h28   #3
Invité régulier
 
Étudiant
Inscription : mai 2008
Messages : 18
Détails du profil
Informations personnelles :
Âge : 23

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : mai 2008
Messages : 18
Points : 7
Points : 7
Envoyer un message via MSN à l'breton du 29
Les variables du calcul b, c, e et g sont des macros variables.

peut tu donner un exemple de calcul dans une étape data et une macro, parce que je ne saisi pas très bien!

merci.
l'breton du 29 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/06/2008, 16h35   #4
Membre Expert
 
Inscription : mars 2005
Messages : 1 028
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 1 028
Points : 1 278
Points : 1 278
Envoyer un message via Yahoo à bahraoui
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
 
%let b=1;
%let c=4;
%let e=6;
%let g=3;
%let a=%sysevalf(&b+&c*&e/&g);
%put &a;
DATA t;
b=1;
c=4;
e=6;
g=3;
a=b+c*e/g;
run;
bahraoui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/06/2008, 17h54   #5
Invité régulier
 
Étudiant
Inscription : mai 2008
Messages : 18
Détails du profil
Informations personnelles :
Âge : 23

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : mai 2008
Messages : 18
Points : 7
Points : 7
Envoyer un message via MSN à l'breton du 29
La fonction SQRT ne marche t elle pas en macro??

Code :
1
2
%let h=sqrt(&b);
%put &h;
resultat journal :
il n'affiche pas 3 !!!!!
l'breton du 29 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/06/2008, 17h56   #6
Invité régulier
 
Étudiant
Inscription : mai 2008
Messages : 18
Détails du profil
Informations personnelles :
Âge : 23

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : mai 2008
Messages : 18
Points : 7
Points : 7
Envoyer un message via MSN à l'breton du 29
Code :
1
2
%let h=%sysevalf(sqrt(&b));
%put &h;
j ai aussi essayé cela, et ca ne marche pas non plus!
l'breton du 29 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/06/2008, 17h59   #7
Membre Expert
 
Inscription : mars 2005
Messages : 1 028
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 1 028
Points : 1 278
Points : 1 278
Envoyer un message via Yahoo à bahraoui
regarde le FAQ et les anciens postes.
Merci
__________________
Consultez les FAQs et les anciens postes avant de poser vos questions. Merci
bahraoui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/06/2008, 18h38   #8
Invité régulier
 
Étudiant
Inscription : mai 2008
Messages : 18
Détails du profil
Informations personnelles :
Âge : 23

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : mai 2008
Messages : 18
Points : 7
Points : 7
Envoyer un message via MSN à l'breton du 29
y a pas la réponse dans le FAQ. j'avais déjà regardé !

ils ne mettent que comment utiliser ces fonctions dans une étape data, et en essayant de l'appliquer à une macro variable ca ne fonctionne pas!!

merci.
l'breton du 29 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/06/2008, 21h25   #9
Membre Expert
 
Inscription : mars 2005
Messages : 1 028
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 1 028
Points : 1 278
Points : 1 278
Envoyer un message via Yahoo à bahraoui
Tu as raison.
La macro %sysfunc permet d'utiliser les fonctions (qu'on utilise dans les étapes data pour lesquelles SAS n'a pas transformé en macro ).
Code :
1
2
3
 
%let h=%sysfunc(sqrt(&b));
%put &h;
__________________
Consultez les FAQs et les anciens postes avant de poser vos questions. Merci
bahraoui est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 18h14.


 
 
 
 
Partenaires

Hébergement Web