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 17/07/2008, 13h21   #1
Membre habitué
 
Avatar de pierre24
 
Inscription : février 2008
Messages : 269
Détails du profil
Informations personnelles :
Âge : 26
Localisation : France, Gironde (Aquitaine)

Informations forums :
Inscription : février 2008
Messages : 269
Points : 106
Points : 106
Envoyer un message via MSN à pierre24
Par défaut [Macro] Création variable dans DATA _NULL_

Bonjour,

puis dans un programme DATA _NULL_ créer une variable DT1 par exemple et la réutiliser dans une proc SQL par la suite :

Exemple :
Code :
1
2
3
4
5
6
7
8
9
10
 
 
DATA _NULL_;
DT1= SUBSTR ( %DTEFFET 2,1);
RUN;
 
PROC SQL;
   CREATE TABLE
      [...]
   WHERE maDate = DT1
Est correct ???
__________________
Pierre24.
http://www.goguel-blog.com
Les racistes sont des gens qui se trompent de colère.
Léopold Sédar Senghor
pierre24 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/07/2008, 13h26   #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
pas possible il faut transfprmer ta variable en macro variable sinon tu la perd.
J'ai ajouté "&DT1"d pour dire que c'est une date. A toi de voir le contexte.
Code :
1
2
3
4
5
6
7
8
9
10
 
DATA _NULL_;
DT1= SUBSTR ( %DTEFFET 2,1);
call symput('dt',dt);
RUN;
 
PROC SQL;
CREATE TABLE
[...]
WHERE maDate = "&DT1"d
__________________
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 17/07/2008, 14h19   #3
Membre habitué
 
Avatar de pierre24
 
Inscription : février 2008
Messages : 269
Détails du profil
Informations personnelles :
Âge : 26
Localisation : France, Gironde (Aquitaine)

Informations forums :
Inscription : février 2008
Messages : 269
Points : 106
Points : 106
Envoyer un message via MSN à pierre24
Que fais tu lorsque tu écris ca :

???
__________________
Pierre24.
http://www.goguel-blog.com
Les racistes sont des gens qui se trompent de colère.
Léopold Sédar Senghor
pierre24 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/07/2008, 15h53   #4
Membre confirmé
 
Inscription : avril 2008
Messages : 233
Détails du profil
Informations personnelles :
Âge : 36

Informations forums :
Inscription : avril 2008
Messages : 233
Points : 216
Points : 216
Il crée une variable macro "dt" et l'attribue la valeur de la variable d'étape data qui s'appelle elle aussi "dt". Si tu veux, le code sera plus simple à comprendre si on choisi les noms différents :
Code :
1
2
3
4
5
6
7
8
9
DATA _NULL_;
DT1= SUBSTR ( %DTEFFET 2,1);
call symput('dt2', dt1);
RUN;
 
PROC SQL;
CREATE TABLE
[...]
WHERE maDate = "&DT2"d
Dans ce cas la variable dt1 est une variable d'étape data qui n'est visible qu'à l'intérieur de cette étape. Et la variable dt2 - est une variable macro qui est visible partout à partir de la ligne de sa création.
green_fr est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/07/2008, 08h30   #5
Membre habitué
 
Avatar de pierre24
 
Inscription : février 2008
Messages : 269
Détails du profil
Informations personnelles :
Âge : 26
Localisation : France, Gironde (Aquitaine)

Informations forums :
Inscription : février 2008
Messages : 269
Points : 106
Points : 106
Envoyer un message via MSN à pierre24
ma date est de type : 01012008. Lorsque je compare mes deux dates ds le WHERE, il me dit :

Citation:

Invalid date/time/datetime constant " 1062008"d
Peux utiliser d'autre formats de dates ???
__________________
Pierre24.
http://www.goguel-blog.com
Les racistes sont des gens qui se trompent de colère.
Léopold Sédar Senghor
pierre24 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/07/2008, 08h46   #6
Expert Confirmé
 
Avatar de olivier.decourt
 
Homme Olivier Decourt
Formateur en informatique
Inscription : avril 2008
Messages : 1 480
Détails du profil
Informations personnelles :
Nom : Homme Olivier Decourt
Âge : 34
Localisation : France

Informations professionnelles :
Activité : Formateur en informatique
Secteur : Conseil

Informations forums :
Inscription : avril 2008
Messages : 1 480
Points : 2 864
Points : 2 864
Bonjour Pierre.
L'écriture autorisée pour les constantes dates est "jjmmmaa"d ou "jjmmmaaaa"d (avec le mois sur 3 lettres en anglais). Donc l'écriture "1062008"d est incorrecte pour SAS.
Avant de te proposer une solution de contournement, je m'interroge : est-ce que la valeur 1062008 correspond au 10/06/2008 ou au 01/06/2008 ?
Autre question : as-tu le code de la macro %DTEFFET ?

Olivier
olivier.decourt est actuellement connecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/07/2008, 08h48   #7
Membre habitué
 
Avatar de pierre24
 
Inscription : février 2008
Messages : 269
Détails du profil
Informations personnelles :
Âge : 26
Localisation : France, Gironde (Aquitaine)

Informations forums :
Inscription : février 2008
Messages : 269
Points : 106
Points : 106
Envoyer un message via MSN à pierre24
En fait ma date est : 01/06/2008 par exemple

Voici le code que j'utilise :

Code :
1
2
3
4
5
 
DATA _NULL_;
DT1= "01062008";
call symput('dt2', dt1);
RUN;
__________________
Pierre24.
http://www.goguel-blog.com
Les racistes sont des gens qui se trompent de colère.
Léopold Sédar Senghor
pierre24 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/07/2008, 09h08   #8
Expert Confirmé
 
Avatar de olivier.decourt
 
Homme Olivier Decourt
Formateur en informatique
Inscription : avril 2008
Messages : 1 480
Détails du profil
Informations personnelles :
Nom : Homme Olivier Decourt
Âge : 34
Localisation : France

Informations professionnelles :
Activité : Formateur en informatique
Secteur : Conseil

Informations forums :
Inscription : avril 2008
Messages : 1 480
Points : 2 864
Points : 2 864
Alors écris plutôt :
Code :
1
2
3
4
 
DATA _NULL_;
call symput('dt2', "01jun2008");
RUN;
Au fait, pourquoi passer par un CALL SYMPUT pour créer une macro-variable ? Si tu en connais d'avance la valeur, il est plus court d'écrire :
Code :
1
2
 
%LET dt2 = 01jun2008 ;
Dans les posts précédents, j'avais l'impression que ta valeur provenait d'un macro %DTEFFET, d'où ma question à ce sujet.
olivier.decourt est actuellement connecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/07/2008, 09h56   #9
Membre habitué
 
Avatar de pierre24
 
Inscription : février 2008
Messages : 269
Détails du profil
Informations personnelles :
Âge : 26
Localisation : France, Gironde (Aquitaine)

Informations forums :
Inscription : février 2008
Messages : 269
Points : 106
Points : 106
Envoyer un message via MSN à pierre24
OK ca marche ! Je connaissais pas ces varaibles macros comme je débute !

Merci
__________________
Pierre24.
http://www.goguel-blog.com
Les racistes sont des gens qui se trompent de colère.
Léopold Sédar Senghor
pierre24 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 21h28.


 
 
 
 
Partenaires

Hébergement Web