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 :

Optimiser une macro


Sujet :

Macro

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    221
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 221
    Points : 108
    Points
    108
    Par défaut Optimiser une macro
    Bonjour
    j'ai une macro comme ci-dessous, qui en fonction du mois d’exécution de la macro, pour le cumul du chiffres d'affaires suivant les différents mois.

    Par exemple pour month_number=3 et an1=2011, on aura Sales_C_2012=ca11 +ca12+ca13.
    ca12= ca pour le mois 2 de l'année 1=2011
    ca02= ca pour le mois 2 de l'année encours 0=2012.
    Code sas : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    %macro create_field (dsn1= , dsn2=);
    	proc sql noprint;
    		select max(mois) into :month_number from Mois_max_&an.;
    		%put &month_number;
    	quit;
    	%LET month_number = &month_number ;	
    data &dsn1;
    	set &dsn2;
    	Sales_C_&an1. =sum(of ca11-ca1&month_number.);
    run;
    %mend;
    Alors mon problème est au niveau du calcul du cumul pour les mois de décembre (mois 12).

    Alors l'opération demandé est:

    Code sas : Sélectionner tout - Visualiser dans une fenêtre à part
    Sales_C_&an1. =sum(of ca11-ca112);

    Dans la log j'ai donc le message:

    Code sas : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Les variables:
    ca20, ca21 etc... ne sont pas initialisées
    Il considère en fait toutes les valeurs entre 11 et 112. Savez-vous comment evitercet avertissement?

    Merci d'avance

  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 ajouter la ligne : option mprint;
    exécuter et poster la log?
    Consultez les FAQs et les anciens postes avant de poser vos questions. Merci

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    221
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 221
    Points : 108
    Points
    108
    Par défaut
    Citation Envoyé par bahraoui Voir le message
    tu peux ajouter la ligne : option mprint;
    exécuter et poster la log?
    J'ai ceci
    Code sas : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    NOTE: Variable ca20 non initialisée.
    NOTE: Variable ca21 non initialisée.
    NOTE: Variable ca22 non initialisée.
    NOTE: Variable ca23 non initialisée..
    NOTE: Variable ca24 non initialisée.
    NOTE: Variable ca25 non initialisée.
    NOTE: Variable ca26 non initialisée.
    NOTE: Variable ca27 non initialisée. etc...

  4. #4
    Modérateur

    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Février 2011
    Messages
    1 624
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Février 2011
    Messages : 1 624
    Points : 3 402
    Points
    3 402
    Par défaut
    hello;

    visiblement ta table ne contient pas les variavles CA20, CA21,... et sans me pencher vers le fond de ta problèmatique. Essaie avec un "COLON" , (les deux point comme jocker) ?

    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
     
    %macro test;
     
    data test;
    	set sashelp.class;
    	%do i=1 %to 10;
    	age&i=age;
    	%end;
    run;
     
    %mend;
     
    %test;
     
     
    data somme;
    	set test;
    	la_sommz= sum (of age:);
    run;
    N'oubliez pas de consulter les FAQ SAS et les cours et tutoriels SAS
    N'oubliez pas de mettre votre message à si la solution donnée résout votre problème

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    221
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 221
    Points : 108
    Points
    108
    Par défaut
    Citation Envoyé par s_a_m Voir le message
    hello;

    visiblement ta table ne contient pas les variavles CA20, CA21,... et sans me pencher vers le fond de ta problèmatique. Essaie avec un "COLON" , (les deux point comme jocker) ?

    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
     
    %macro test;
     
    data test;
    	set sashelp.class;
    	%do i=1 %to 10;
    	age&i=age;
    	%end;
    run;
     
    %mend;
     
    %test;
     
     
    data somme;
    	set test;
    	la_sommz= sum (of age:);
    run;
    Merci ça marche. Dans mon cas il suffit d'écrire:

    Code sas : Sélectionner tout - Visualiser dans une fenêtre à part
    Sales_C_&an.  =sum(of ca1:);

  6. #6
    Modérateur

    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Février 2011
    Messages
    1 624
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Février 2011
    Messages : 1 624
    Points : 3 402
    Points
    3 402
    Par défaut
    oui du coup , tu n'as plus besoin de la macro
    N'oubliez pas de consulter les FAQ SAS et les cours et tutoriels SAS
    N'oubliez pas de mettre votre message à si la solution donnée résout votre problème

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

Discussions similaires

  1. [XL-2010] Optimiser une macro
    Par laguernette dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 01/11/2013, 22h56
  2. [XL-2003] Optimiser une macro
    Par mikadoo57 dans le forum Macros et VBA Excel
    Réponses: 21
    Dernier message: 26/03/2013, 14h59
  3. [XL-2003] Optimiser une macro VBA
    Par momo93240 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 19/07/2011, 16h46
  4. [XL-2003] Optimiser une macro de mise en forme d'un Tableau
    Par mouncefdi dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 10/04/2009, 12h19
  5. Optimiser une macro
    Par PiliSql dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 20/05/2008, 20h18

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