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

Macros et VBA Excel Discussion :

Option Explicit : peut on s'en passer ?


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Inscrit en
    Juillet 2007
    Messages
    239
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 239
    Points : 307
    Points
    307
    Par défaut Option Explicit : peut on s'en passer ?
    Bonjour,

    ma question va sans doute irriter les puristes mais ..

    J'ai un grand nombre de macro déja développées et diffusées dans l'entreprise. Avec le renouvellement des postes de travail et l'évolution du parc logiciel ( passage Excel 2010) , les problèmes apparaissent , les macros ne fonctionnent plus .

    Le plus souvent il s'agit de déclaration de variable absentes.
    Je n'utilise pas l'option explicit et dans les options , 'Déclarations des variables obligatoire' n'est pas cochée et pourtant il y a blocage en cas de déclaration manquante. Peut on contourner le problème pour éviter les retouches de code nombreuses ?
    Par le passé , j'ai déja rencontré le problème sur des postes nouvellement installés , y a-t-il une autres options ou un paramétre à utiliser.

  2. #2
    Membre émérite Avatar de Fvandermeulen
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2007
    Messages
    1 869
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 869
    Points : 2 662
    Points
    2 662
    Par défaut
    Salut,

    Bien entendu que tu peux t'en passer mais ce n'est pas qu'une question de faire ou ne pas faire plaisir aux puristes.

    La déclaration des variables a de nombreux avantages, c'est un bon moyen de vérifier que tu n'a pas fait de coquille dans ton code par exemple.

    De plus, une variable par défaut en Variant peut à un moment ou à un autre fausser le résultat attendu, je n'ai plus d'exemple concrèt en tête mais ça m'est déjà arrivé.

    Mon conseil serait plutôt, dès qu'un utilisateur rencontre un bug, tu fais les corrections et déclarations nécessaires.
    Et surtout prend l'habitude de le faire dès que tu codes, tu verras qu'au bout du compte ça te fera gagner du temps.

    Sans quoi, tu dois de toute façon supprimer toutes les lignes Option Explicit dans les codes ou te pencher sur les Tutos qui t'explique comment, avec du VBA, modifier des codes existants, mais c'est pas du petit boulot...

    A+
    N'oubliez pas le si votre problème est solutionné.

  3. #3
    Expert éminent sénior
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    6 803
    Détails du profil
    Informations personnelles :
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Décembre 2007
    Messages : 6 803
    Points : 32 058
    Points
    32 058
    Par défaut
    Se passer d'option explicit est une tendance fréquente chez les débutants. Or, à mon sens, seuls les experts(dont je ne suis pas), sont à même d'exploiter la puissance du typage dynamique. Même un expérimenté comme moi se fera surprendre par les pièges inhérents au typage dynamique.

    Et on est jamais sur de qui récupère la macro derrière soi. Souvent, ce n'est pas un expert.

    Donc, option explicit, déclaration des données, sont indispensables. Parceque sans elles, on perd le contrôle sur les formats, et on s'expose à des plantages très ennuyeux. J'ai eu des soucis, par le passé, de confusion entre integer et double. Je perdais les décimales. En forçant le format à quelque chose de plus adapté, je les ai gardées. Plus tard; j'ai découvert le format currency, qui est une petite merveille dès qu'on travaille sur des sous. Ne pas déclarer sa variable montant, c'est risquer un typage dynamique en virgule flottante, et donc des imprécisions.

    en bref, +1 avec Fvandermeulen. C'est chiant, mais l'alternative peut avoir un cout bien plus grand - et bien plus sournois.
    Les 4 règles d'airain du développement informatique sont, d'après Michael C. Kasten :
    1)on ne peut pas établir un chiffrage tant qu'on a pas finalisé la conception
    2)on ne peut pas finaliser la conception tant qu'on a pas complètement compris toutes les exigences
    3)le temps de comprendre toutes les exigences, le projet est terminé
    4)le temps de terminer le projet, les exigences ont changé
    Et le serment de non-allégiance :
    Je promets de n’exclure aucune idée sur la base de sa source mais de donner toute la considération nécessaire aux idées de toutes les écoles ou lignes de pensées afin de trouver celle qui est la mieux adaptée à une situation donnée.

  4. #4
    Membre averti
    Inscrit en
    Juillet 2007
    Messages
    239
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 239
    Points : 307
    Points
    307
    Par défaut
    Ma question c'était surtout comment faire pour que l'option explicit ne soit pas le mode par défaut ? Car ainsi mes anciennes macros fonctionnent sur les nouveaux postes sans interventions.
    Il est clair qu'un travail 'propre' en informatique nécessite le typage des données.
    Je reste persuadé qu'il y a un paramétre qui permet de se passer des déclarations ( même si il y un risque d'erreur supplémentaire qu'avec des déclarations explicites de variable).

  5. #5
    Expert éminent
    Avatar de Didier Gonard
    Homme Profil pro
    Formateur Office et développeur VBA en freelance
    Inscrit en
    Février 2008
    Messages
    2 805
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Formateur Office et développeur VBA en freelance

    Informations forums :
    Inscription : Février 2008
    Messages : 2 805
    Points : 6 696
    Points
    6 696
    Par défaut
    Bonjour,

    Option Explicit, n'est pas un mode, si tu l'as coché dans les options, il s'écrit en dur, si tu le décoches, il ne sera pas inscrit dans les prochains modules crées, mais il restera écrit en dur sur ceux qui existaient

    (d'ailleurs, sinon ceux que tu rajoutes manuellement sur des versions où l'automatisme n'est pas coché disparaîtraient )

    Donc le moyen le plus rapide pour arriver à tes fins et comme indiquer par Fvandermeulen et le faire par code...


    Cordialement,

    Ps : si le côté technique de la réponse = OK ou pas => pensez à cliquer sur les pouces et quand question résolue à la taguer résolue, et chaque action vous rapporte des points

    Didier
    Didier Gonard

    Dernier tutoriel :
    Le VBA qu'est ce que c'est ?
    Tutoriels : Voir la liste de mes tutoriels Excel & VBA et mon site pro sur ma Page DVP
    Cours et tutoriels pour apprendre Excel
    N'oubliez pas de mettre : ..quand c'est le cas !

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

Discussions similaires

  1. Option Explicit et erreur variable non déclarée
    Par petitours dans le forum VBA Access
    Réponses: 2
    Dernier message: 23/04/2008, 15h38
  2. À quoi sert le code "Option Explicit"
    Par egg3774 dans le forum VBA Access
    Réponses: 3
    Dernier message: 15/06/2007, 05h57
  3. Problème avec "option explicit"
    Par tribaleur dans le forum ASP
    Réponses: 3
    Dernier message: 01/06/2006, 10h46
  4. option explicite????!!!
    Par shinrei dans le forum ASP
    Réponses: 1
    Dernier message: 14/04/2006, 18h09
  5. Utilisation de Option explicit
    Par Perihan dans le forum ASP
    Réponses: 5
    Dernier message: 29/10/2003, 11h43

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