Précédent   Forum des professionnels en informatique > Logiciels > Solutions d'entreprise > Business Intelligence > SAS > Débutez
Débutez Forum concentrant les premières questions que l'on se pose en tant que débutant
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/01/2012, 17h28   #1
Invité régulier
 
Inscription : janvier 2012
Messages : 15
Détails du profil
Informations forums :
Inscription : janvier 2012
Messages : 15
Points : 6
Points : 6
Par défaut Nom de table si iteration

Bonjour à tous,

J'aimerais savoir comment créer une table SAS dont le nom dépend de l'itération à laquelle je suis. J'explique :

Imaginons que j'ai une table avec une colomne année. Pour extraire une année, j'exécute la commamde suivante :

Code :
1
2
3
4
DATA Annee1;
	SET InitialTable;
	WHERE Annee=1;
RUN;
Mais voilà, j'aimerais l'automatiser pour traiter un nombre d'années N de telle sorte à avoir les tables Annee1, Annee2... AnneeN

Je voudrais utiliser une macro avec la commande "%getannee(i)" avec i variant de 1 à N et qui crée la table Anneei (créant donc les tables Annee1, Annee2... AnneeN).

J'espère avoir été clair, sinon je peux essayer de le reformuler.

Merci pour votre aide

Sebastien
Cannaould est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 17h55   #2
Modérateur
 
Homme Samir SELMANE
Consultant en Business Intelligence
Inscription : février 2011
Messages : 1 014
Détails du profil
Informations personnelles :
Nom : Homme Samir SELMANE
Localisation : France

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

Informations forums :
Inscription : février 2011
Messages : 1 014
Points : 1 724
Points : 1 724
Hello;
tu peux t'insperer de cet exemple :

Code :
1
2
3
4
5
6
7
 
DATA _null_;
SET sashelp.class;
call execute ( "data "||LEFT(name) ||"; set sashelp.class;
if name="||quote(name)||";run;"
);
run;
s_a_m est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 17h58   #3
Membre Expert
 
Avatar de MEGAMIND2
 
Homme Brice Beare
Paris
Inscription : janvier 2011
Messages : 960
Détails du profil
Informations personnelles :
Nom : Homme Brice Beare
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Paris

Informations forums :
Inscription : janvier 2011
Messages : 960
Points : 1 371
Points : 1 371
Bonjour,
Tu peux t'inspirer de ce programme, sachant que tu ne peux pas nommer une table du style 789.

Code :
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
DATA test;
input annee$ vary;
cards;
234 90
438 984
834 877
425 838
;
run;
 
%MACRO M;
 
PROC SQL noprint;
SELECT annee INTO: liste_annee separated BY ' ' FROM test;
SELECT count(*) INTO: nb FROM test;
QUIT;
 
%DO i=1 %TO &nb.;
%let an&i=%scan(&liste_annee,&i.,' ');
 
DATA table_&&an&i;
SET test;
WHERE annee="&&an&i";
run;
 
 
%end;
 
%mend;
%M;
MEGAMIND2 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 18h05   #4
Modérateur
 
Homme Samir SELMANE
Consultant en Business Intelligence
Inscription : février 2011
Messages : 1 014
Détails du profil
Informations personnelles :
Nom : Homme Samir SELMANE
Localisation : France

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

Informations forums :
Inscription : février 2011
Messages : 1 014
Points : 1 724
Points : 1 724
Brice ;
Code :
1
2
SELECT DISTINCT annee INTO
s_a_m est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 18h06   #5
Membre Expert
 
Avatar de MEGAMIND2
 
Homme Brice Beare
Paris
Inscription : janvier 2011
Messages : 960
Détails du profil
Informations personnelles :
Nom : Homme Brice Beare
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Paris

Informations forums :
Inscription : janvier 2011
Messages : 960
Points : 1 371
Points : 1 371
MEGAMIND2 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 18h10   #6
Modérateur
 
Homme Samir SELMANE
Consultant en Business Intelligence
Inscription : février 2011
Messages : 1 014
Détails du profil
Informations personnelles :
Nom : Homme Samir SELMANE
Localisation : France

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

Informations forums :
Inscription : février 2011
Messages : 1 014
Points : 1 724
Points : 1 724
Exemple avec variable numérique :
Code :
1
2
3
4
5
6
7
 
DATA _null_;
SET sashelp.class;
call execute ( "data _"||LEFT(AGE) ||"; set sashelp.class;
if AGE="||AGE||";run;"
);
run;
replaces age par ta variable ANNEE et sashelp.class par le nom de ta table et le tour est joué !!!
s_a_m est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/01/2012, 14h01   #7
Invité régulier
 
Inscription : janvier 2012
Messages : 15
Détails du profil
Informations forums :
Inscription : janvier 2012
Messages : 15
Points : 6
Points : 6
Merci,
Je dois avouer que j'ai besoin d'un peu de temps pour digérer vos conseils mais je suis sur que ca va bien m'aider. Je reporte cette étape à un peu plus tard...

Sebastien
Cannaould est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 00h46.


 
 
 
 
Partenaires

Hébergement Web