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 :

Macro qui crée une table SAS qui contient les mots d'une chaine de caractères


Sujet :

Macro

  1. #1
    Membre confirmé
    Femme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2013
    Messages : 55
    Par défaut Macro qui crée une table SAS qui contient les mots d'une chaine de caractères
    Slt,

    Je veux créer une macro qui crée une table SAS qui contient les mots d'une chaine de caractères.
    La table que je veux en sortie doit contenir la variable TOTO :

    TOTO
    match
    de
    foot

    "match", "de" et "foot" sont en faite le contenu de la variable TOTO.

    Merci d'avance!

  2. #2
    Membre confirmé
    Femme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2013
    Messages : 55
    Par défaut mon idée.
    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
    %let chaine = match de foot
     
    %macro creat_tab;
     
    %local num_obs ;
     
    %let n = %eval(%sysfunc(count(&chaine,%str( )))+1);  /*compte le nbre de mot de la chaine*/
     
    data tab_chaine;
     
    %do num_obs = 1 %to &n ;  
    length TOTO $ 8.;
    TOTO = %scan(&chaine, &num_obs); 
    %end;
     
    run;
     
    %mend;
    Mais il me crée 4 variable au lieu d'une.

  3. #3
    Membre Expert
    Homme Profil pro
    Attaché statisticien
    Inscrit en
    Mai 2011
    Messages
    687
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Attaché statisticien
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2011
    Messages : 687
    Par défaut
    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
     
    %let chaine = match de foot;
     
    %macro creat_tab;
     
    %local num_obs ;
     
    %let n = %eval(%sysfunc(count(&chaine,%str( )))+1); /*compte le nbre de mot de la chaine*/
     
    data tab_chaine;
     
    %do num_obs = 1 %to &n ;
    length TOTO $ 8.;
    TOTO = "%scan(&chaine, &num_obs)";
    OUTPUT;
    %end;
     
    run;
     
    %mend;
    %creat_tab;

  4. #4
    Membre confirmé
    Femme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2013
    Messages : 55
    Par défaut ça marche!
    ça marche merci.
    mais juste une petite question. c'est les quotes qui ont permis de passer à la ligne suivante ?

  5. #5
    Membre Expert
    Homme Profil pro
    Attaché statisticien
    Inscrit en
    Mai 2011
    Messages
    687
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Attaché statisticien
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2011
    Messages : 687
    Par défaut
    Salut,
    non c'est l'OUTPUT qui a permis de passer aux lignes suivantes.
    Et les " " étaient nécessaires, sinon ça ne fait pas ce que tu crois que ça fait
    bon courage

  6. #6
    Membre confirmé
    Femme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2013
    Messages : 55
    Par défaut
    !!!

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 21/06/2012, 15h40
  2. Modifier les données d'une table sas
    Par m.brahim dans le forum SAS Base
    Réponses: 4
    Dernier message: 14/11/2011, 14h24
  3. Réponses: 2
    Dernier message: 06/07/2010, 00h45
  4. Réponses: 4
    Dernier message: 22/03/2010, 22h24
  5. chercher les éléments d'une table B qui ne sont pas dans la table A
    Par Cupidon dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 11/01/2008, 14h40

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