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 :

ACM : macro plotit - option qui permet de mettre une couleur pour chaque variable


Sujet :

Macro

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Juin 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Juin 2011
    Messages : 5
    Points : 6
    Points
    6
    Par défaut ACM : macro plotit - option qui permet de mettre une couleur pour chaque variable
    Bonjour,

    Je réalise une ACM via SAS, afin d'améliorer la représentation graphique de mes variables à partir de la maco Plotit, j'aimerais savoir si vous connaissez l'option qui nous permets de mettre une couleur pour chaque variable.

    A part cette macro, auriez vous une macro SAS qui me permetrait de résoudre mon soucis?

    Merci

  2. #2
    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 : 46
    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
    Bonjour.
    Personnellement je n'utilise pas de macros, juste un peu de code. Si les indicatrices sont bien préparées en amont de la proc CORRESP, récupérer le nom des variables n'est pas très compliqué.
    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
    PROC FORMAT ;
      VALUE poids
       LOW - 110 = "< 50 kg"
       OTHER     = "> 50 kg"
      ;
      VALUE taille
       LOW - 63 = "< 1,60m"
       OTHER    = "> 1.60m"
      ;
    RUN ;
    PROC TRANSREG DATA=sashelp.class NOPRINT DESIGN ;
      MODEL CLASS(sex age weight height/ZERO=NONE SEP="=") ;
      FORMAT weight poids. height taille. ;
      ID name ;
      OUTPUT OUT=work.disjonctif (DROP=intercept _type_ _name_) ;
    RUN ;
    PROC CORRESP DATA=work.disjonctif DIMENS=%EVAL(&_trgIndN - 4)
    			 OUTC=work.acm NOROW=PRINT NOCOLUMN=PRINT ;
      VAR &_trgind ;
      ID name ;
    RUN ;
    DATA work.variables ;
      SET work.acm (WHERE=(_type_="VAR")) ;
      var = SCAN(name,1,"=") ;
      val = SUBSTR(name,INDEX(name,"=")+1) ;
    RUN ;
    SYMBOL i=none v=dot h=1.5 pointlabel=("#val") ;
    PROC GPLOT DATA=work.variables ;
      PLOT dim2 * dim1 = var / HREF=0 VREF=0 ;
    RUN ; QUIT ;
    GOPTION RESET=SYMBOL ;
    Bon courage.
    Olivier
    Bon courage.
    Olivier

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Juin 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Juin 2011
    Messages : 5
    Points : 6
    Points
    6
    Par défaut
    Citation Envoyé par olivier.decourt Voir le message
    Bonjour.
    Personnellement je n'utilise pas de macros, juste un peu de code. Si les indicatrices sont bien préparées en amont de la proc CORRESP, récupérer le nom des variables n'est pas très compliqué.
    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
    PROC FORMAT ;
      VALUE poids
       LOW - 110 = "< 50 kg"
       OTHER     = "> 50 kg"
      ;
      VALUE taille
       LOW - 63 = "< 1,60m"
       OTHER    = "> 1.60m"
      ;
    RUN ;
    PROC TRANSREG DATA=sashelp.class NOPRINT DESIGN ;
      MODEL CLASS(sex age weight height/ZERO=NONE SEP="=") ;
      FORMAT weight poids. height taille. ;
      ID name ;
      OUTPUT OUT=work.disjonctif (DROP=intercept _type_ _name_) ;
    RUN ;
    PROC CORRESP DATA=work.disjonctif DIMENS=%EVAL(&_trgIndN - 4)
    			 OUTC=work.acm NOROW=PRINT NOCOLUMN=PRINT ;
      VAR &_trgind ;
      ID name ;
    RUN ;
    DATA work.variables ;
      SET work.acm (WHERE=(_type_="VAR")) ;
      var = SCAN(name,1,"=") ;
      val = SUBSTR(name,INDEX(name,"=")+1) ;
    RUN ;
    SYMBOL i=none v=dot h=1.5 pointlabel=("#val") ;
    PROC GPLOT DATA=work.variables ;
      PLOT dim2 * dim1 = var / HREF=0 VREF=0 ;
    RUN ; QUIT ;
    GOPTION RESET=SYMBOL ;
    Bon courage.
    Olivier
    Merci pour la rapidité de ta réponse, c'est ce que je voulais réaliser!

  4. #4
    Futur Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2013
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Mai 2013
    Messages : 14
    Points : 5
    Points
    5
    Par défaut
    Bonjour,

    navrée de déterrer le sujet, j'ai exactement le même besoin mais je n'ai fichtre rien compris à la solution !

    Je travaille sur des modalités alphanumériques et j'aimerais que si ma modalité contient 0 elle s'affiche en vert, si elle contient 1 en jaune, 2 en orange, 3 en rouge sur mon arbre de classification ascendante hiérarchique et sur le graphique de mon ACM....

    Je patauge pas mal dans les options à la base alors rajouter une condition en prime je m'en sors pas !!


    Si quelqu'un avait la gentillesse de m'expliquer comment faire ça ce serait top !

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

Discussions similaires

  1. Macro qui permet d'appliquer une macro sur un fichier excel
    Par zak-mouk dans le forum Général VBA
    Réponses: 2
    Dernier message: 23/06/2015, 17h15
  2. [XL-MAC 2011] Macro qui permet de décocher une checkbox
    Par Sorcierloup dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 05/01/2011, 14h20
  3. Macro qui permet de décocher une checkbox
    Par vince2712 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 24/08/2009, 08h49
  4. Macro qui permet de mettre une macro sur une poste
    Par Tinien dans le forum VBA Word
    Réponses: 4
    Dernier message: 26/11/2008, 01h17
  5. Code qui permet de garder BO ouvert pour toutes les macros
    Par Alexandra0907 dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 21/05/2008, 12h56

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