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 :

A quel niveau gérer les erreurs


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre émérite Avatar de issoram
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2009
    Messages
    665
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2009
    Messages : 665
    Par défaut A quel niveau gérer les erreurs
    Bonjour,

    Tout est dans le titre..

    Par exemple pour le pseudo-code ci dessous, où est-il le plus judicieux de gérer les erreurs?
    • Au sein de la procédure de lecture pour une gestion plus fine
    • Au sein de la procédure appelante pour une gestion globale au sein du code principal.
    • Ou alors peut être dans les 2, sous peine de redondance?

    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
    'Procédure qui lit un fichier
    Sub lecture_fichier(byval nomFichier as String)
     
    Ouverture fichier
    '.....
    'gestion erreur ouverture ici?
    '.......
    Lecture fichier
    '......
    'gestion erreur fermeture ici?
    '......
    Fermeture fichier
    '......
    end Sub
     
    'Procédure appelante
    sub test()
    'gestion erreur globale ici? 
    lecture_fichier("C:\.....\test.txt")
    end sub
    Merci d'avance.

  2. #2
    Membre éclairé Avatar de nchal
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2012
    Messages
    512
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2012
    Messages : 512
    Par défaut
    Salut,

    Je pense que sa dépend de ton besoin. Soit tu veux que l'utilisateur sache juste que ça n'a pas marché, soit tu veux qu'il sache où sa n'a pas marché. Après au niveau de performance, je ne pense que que faire 2 vérifications gène plus qu'en faire une seule (sa dépend bien sur de la quantité de fichier).
    D'un point de vue personnel, je préfère gérer les erreurs finement, donc dans ton cas, dans la procédure de lecture.

  3. #3
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    Bonjour,

    Si c'est pour gérer l'erreur en cas de non existence du fichier tu peux faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    If Dir("Chemin\Fichier.xls") <> "" Then
        'ouverture fichier
    Else
        MsgBox "Le fichier n'a pas été trouvé"
    End If

  4. #4
    Membre émérite Avatar de issoram
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2009
    Messages
    665
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2009
    Messages : 665
    Par défaut
    Bonjour et merci Fring,

    Question méthode je fais souvent comme ci dessous
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    On Error Resume Next
    instruction   'Instruction pouvant générer une erreur
    If err.number<>0 then
       msgbox "Une erreur s'est produite lors de .... : " & err.Description 
    end if
    On error goto 0
    Err.clear
    Ma question porte plus sur la philosophie de la gestion d'erreurs que sur la méthodologie à employer:
    - Si je gère les erreurs au plus haut niveau (dans le prog principal)=> moins de travail, plus de clarté du code (pas de gestion d'erreurs disséminées un peu partout)
    - mais perte de finesse dans la gestion d'erreurs.

    Quel est selon vous le bon compromis? De quelle manière gérez vous vos exceptions?

    Merci à tous

  5. #5
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    L'exemple était pour te montrer que lorsqu'on peut éviter de provoquer une erreur autant le faire.

    Pour les erreurs inévitables, tu y as répondu toi même à ta question

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

Discussions similaires

  1. [Sécurité] [PEAR::Auth] Gérer les erreurs de connexion
    Par lamimolette75 dans le forum Langage
    Réponses: 1
    Dernier message: 18/09/2006, 18h47
  2. Proc. Stock. : Gérer les erreurs
    Par audreyc dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 29/03/2006, 14h51
  3. gérer les erreurs intebase avec delphi
    Par mondanikoffi dans le forum Bases de données
    Réponses: 1
    Dernier message: 14/12/2004, 15h46

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