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 :

Selection des tables d'une liste de table


Sujet :

Macro

  1. #1
    Membre à l'essai
    Inscrit en
    Juillet 2008
    Messages
    19
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 19
    Points : 22
    Points
    22
    Par défaut Selection des tables d'une liste de table
    Bonjour,

    Voila je voudrais selectionner que les tables qui contienent _EA_.
    Comment faire?

    Je vous donne le code:

    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
    %LET LIST_FIC = Ptf_moto_20080630 Ptf_moto_ea_20080630
    				RESIL_moto_20080630 RESIL_moto_ea_20080630 
    				Ptf_susp_moto_20080630 Ptf_susp_moto_ea_20080630;
     
    DATA _NULL_;
    ARRAY VECTEUR &LIST_FIC;
    CALL SYMPUT ('nombre',dim(vecteur));
    RUN;
     
    %PUT &NOMBRE	;
     
    %DO I = 1 %TO &NOMBRE ; 
     
    %LET VARIABLE = %SCAN(&LIST_FIC,&i);
    %LET VAR1     = %UPCASE(&VARIABLE);
     
    PROC SQL NOPRINT;
     
    CREATE TABLE &variable AS SELECT *
    FROM DEMGAN.&variable
    WHERE CIE = "GAN" ;
    /*AND &VARIABLE contains '_EA_';*/
     
    QUIT;
     
     
    DATA &variable (where=(cie in ('555')));
    SET DEMGAN.&variable;
     
    /***je pernd que les tables qui contiennent EA***/
     
     
    RUN;

    Dans l'étape DATA SET, je veux prendre ke les table qui contiennent EA.
    Avez vous une idée? contains ne fonctionne pas

  2. #2
    Membre émérite

    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mars 2005
    Messages
    1 364
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 364
    Points : 2 329
    Points
    2 329
    Par défaut
    tu peux utiliser la fonction index qui renvoie 0 si l'élément n'existe pas.

  3. #3
    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
    Pour préciser l'idée de Bahraoui : tu peux tester que la valeur de &VARIABLE contient _EA_ avec la macro-fonction %INDEX, et déclencher ou non la proc SQL selon les cas.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    	%DO i=1 %TO &nombre ;
    		%LET VARIABLE = %UPCASE(%SCAN(&LIST_FIC,&i)) ;
    		%IF %INDEX(&VARIABLE, _EA_) > 0 %THEN %DO ;
    			PROC SQL ;
    			QUIT ;
    		%END ;
    	%END ;
    Olivier

  4. #4
    Membre à l'essai
    Inscrit en
    Juillet 2008
    Messages
    19
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 19
    Points : 22
    Points
    22
    Par défaut
    Ca marche.merci olivier et bahraoui.

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

Discussions similaires

  1. [LibreOffice][Base de données] Recuperer une liste de tables et une liste de champs d'une table sur LibreOffice & OpenOffice
    Par gerard.sauvage dans le forum OpenOffice & LibreOffice
    Réponses: 2
    Dernier message: 08/04/2014, 12h35
  2. Afficher une partie de table dans une liste ?
    Par gsacre dans le forum Access
    Réponses: 3
    Dernier message: 05/12/2011, 15h26
  3. Réponses: 18
    Dernier message: 13/06/2007, 16h17
  4. Réponses: 7
    Dernier message: 23/04/2007, 15h35
  5. Réponses: 9
    Dernier message: 19/09/2006, 19h27

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