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

Python Discussion :

Différence en boucles if et exceptions


Sujet :

Python

  1. #1
    Membre confirmé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2004
    Messages
    144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2004
    Messages : 144
    Par défaut Différence en boucles if et exceptions
    Bonjour

    De profil profil ingénieur système Linux, je me remet doucement au dev POO (déjà abordé pendamt mes études) et je me repose la même question en évoluant sur Python, à savoir la difféence entre les boucles conditionnelles (genre if then ) et les exceptions (qui m'ont l'air de if évolués, je me trompe?).

    En effet. j'ai toujours beaucoup de mal à cerner comment marchent les exceptions (leur principe....)

    quelqu'un peut-il m'aider?

    merci

    kondor76

  2. #2
    Membre Expert

    Homme Profil pro
    Ingénieur calcul scientifique
    Inscrit en
    Mars 2013
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur calcul scientifique

    Informations forums :
    Inscription : Mars 2013
    Messages : 1 229

  3. #3
    Membre émérite

    Homme Profil pro
    Ingénieur
    Inscrit en
    Août 2010
    Messages
    662
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2010
    Messages : 662
    Par défaut
    Salut,

    Effectivement, la philosophie de Python c'est de demander pardon plutôt que la permission. Mais cela ne veut pas dire qu'il est préférable de faire ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    try:
        x = a / c
    except ZeroDivisionError as e:
        # quelque chose
    à
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if c != 0:
        x = a / c
    else:
       # quelque chose
    J

  4. #4
    Expert confirmé Avatar de papajoker
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2013
    Messages
    2 324
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nièvre (Bourgogne)

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

    Informations forums :
    Inscription : Septembre 2013
    Messages : 2 324
    Par défaut
    bonjour

    Je dirais que surtout une exception remonte le code, elle est propagée au parent
    Rien ne nous oblige à la relever à l'instant T

    Sans exception, on se retrouve avec un code du type Go/Rust ou il faut retourner (en plus) un code erreur pour chaque fonction

    Par exemple si on utilise une librairie, sans exceptions, on ne serait pas comment est gérée une erreur : la fonction retourne quoi ? une valeur par défaut, null ... du coup on a aucune lecture sur le problème et un retour "null" est-il une erreur ou une valeur probable ???
    Alors qu'avec un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    try:
       utils.SaveMyWork(filename, datas)
    except ...:
    j'ai la possibilité de voir un problème de droits sur les fichiers ou un nom de fichier invalide et donc de gérer le problème au niveau le plus souhaitable pour moi - par exemple, à ce niveau je vais pouvoir afficher une fenêtre popup alors que c'est impensable dans la fonction

    De plus, ce n'est pas à une petite fonction d'interrompre le programme automatiquement, c'est au programme de faire un choix en fonction de l'erreur - donc on déclenche des exceptions dans les fonctions et la gestion est reportée à l'appelant

  5. #5
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 841
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 841
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par kondor76 Voir le message
    boucles conditionnelles (genre if then )
    Ben déjà tu éviteras de parler de "boucle if" si tu veux pas passer pour un gros nul tout ingénieur Linux de profil que tu es.

    Citation Envoyé par kondor76 Voir le message
    En effet. j'ai toujours beaucoup de mal à cerner comment marchent les exceptions (leur principe....)
    Une exception c'est quelque chose d'exceptionnel. Donc déjà dans la philosophie, ce n'est pas la même chose qu'un choix X ou Y en fonction des circonstances.

    De plus une exception ne se traite pas forcément au moment où elle se produit. Elle peut se produire dans la fonctionX et remonter la pile des appels pour être traitée dans la fonctionY 5 niveaux au dessus.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  6. #6
    Membre confirmé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2004
    Messages
    144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2004
    Messages : 144
    Par défaut
    Hello

    Merci pour vos réponse,

    Alors d'après vos post j'ai l'impression que les exception ont l'air d'avoir un format pré-défini, surtout ou niveau du except, je me trompe?

    par exemple ZeroDivisionError......

    Merci

    kondor76

  7. #7
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 841
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 841
    Billets dans le blog
    1
    Par défaut
    Ce sont des objets effectivement déjà définis. C'est normal. Si Python doit les invoquer il faut qu'il les connaisse.
    Elles se déploient en arbre depuis une racine "BaseException" mais généralement on ne monte pas aussi haut car ça englobe aussi les exceptions systèmes comme le KeyboardInterrupt (ctrl-c) donc si on veut monter au plus haut des exceptions de programmation on se contente de "Exception" qui est une des premières sous-branches.
    Le ZeroDivisionError dont tu parles fait partie de la branche "ArithmeticError". Ca signifie que si tu attrappes cet "ArithmeticError" tu attrapperas aussi tout ce qui est en dessous comme le ZeroDivisionError.
    Tu peux aussi te créer les tiennes que tu pourras faire hériter des officielles.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  8. #8
    Expert confirmé Avatar de papajoker
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2013
    Messages
    2 324
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nièvre (Bourgogne)

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

    Informations forums :
    Inscription : Septembre 2013
    Messages : 2 324
    Par défaut
    Et on peut créer ces propres exception fonctionnelles (au niveau de l'application)
    SoldeNegatifException, LoginObligatoireException, AdminOnlyException, PourAdulteException, ConfigBadFormat , ...
    On déclenche ces exceptions après in "if" mais aussi après avoir intercepté une exception bas niveau

  9. #9
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 083
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 083
    Par défaut
    En effet. j'ai toujours beaucoup de mal à cerner comment marchent les exceptions (leur principe....)
    Ce qui est important est de savoir quand utiliser les exceptions ou quand utiliser les conditions.

    La question qu'il faut/faudrait toujours se poser, c'est qu'est-ce qui se passe au cas où... ?

    Soit j'arrête le programme
    Soit je continue en modifiant ce qu'il faut
    Soit je fais l'un ou l'autre ci-dessus selon certaines conditions
    Soit ...

    Bref comment doit réagir le programme ? C'est un besoin conceptuel.

    Quand l'erreur n'est pas grave, on peut utiliser un système de log qui prévient d'un petit dysfonctionnement non bloquant, mais qu'il faudra remédier un jour ou l'autre (ce n'est pas une urgence).

    Il faut donc se poser les bonnes questions et souvent les réponses sont apportées par le métier, qui définit les règles (cahier des charges, ateliers, ...)

    La bonne réponse à ta question n'existe pas, en terme général, c'est du cas par cas !

  10. #10
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Bonjour

    Pour moi, le "if then else" fait partie du déroulement normal du programme, mais le "try...except" représente une rupture dans ce déroulement, correspondant à un évènement anormal (et en principe rare).

    Dans certains cas on pourrait utiliser "try...except" dans le déroulement normal. Par exemple, la méthode .index(...) d'une liste déclenche une exception "ValueError" si la valeur cherchée ne s'y trouve pas, et on pourrait donc l'utiliser pour tester cette possibilité. Mais j'en reste au principe ci-dessus: je n'utilise try...except que pour gérer quelque chose d'anormal.

  11. #11
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 841
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 841
    Billets dans le blog
    1
    Par défaut
    A un moment donné, j'ai voulu détecter si un truc était itérable (listes, tuples, etc). Mais je ne pouvais pas faire un if classique style isinstance(truc, (list, tuple, dict)) car il y a des tas de trucs itérables (OrderedDict, NamedTuple) et même des trucs qui peuvent en hériter sans que je le sache.
    Je me suis donc servi du try/except.
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    try:
        iter(x)
    except TypeError:
        # Pas itérable
    else:
        # Itérable

    On peut aussi s'en servir comme contrôle de saisie
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    try:
        rep=int(input("Entrez un nombre"))
    except ValueErrror:
        print("Mauvaise saisie !!!")

    Toujours cette histoire de pardon/permission souvent plus facile à implémenter qu'un if...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  12. #12
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 762
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 762
    Par défaut
    Salut,

    Pour voir les choses un peu différemment, boucles et conditions permettent d'écrire une "fonctionnalité"...

    Exemple définir une variable a en fonction de la valeur de n peut s'écrire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if n < 10:
       a = 1
    else:
       a = 0
    mais on peut pousser ces instructions dans une fonction:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    def f(n):
         if n < 10:
            a = 1
         else:
            a = 0
         return a
    Dans ce cas, définir la variable a se fera via a = f(n).

    Tout ce qu'on a besoin de savoir de la fonction se résume à sa description: retourne 1 si n < 10, 0 sinon. Les instructions que f va dérouler pour retourner ce résultat n'ont aucune importance (tant qu'elle fait le job), elles sont "cachées". La fonction f pourrait même être sortie d'une bibliothèque écrite dans un autre langage.

    En écrivant a = f(n) on invente une nouvelle relation que l'on traduit parfois par une hiérarchie appelant/appelée, client/service,... qui sort complètement de la séquence d'instructions basiques construite avec boucles et condition...

    Et on se retrouve aussi avec un "aléa" que faire si la fonction "f" ne peut pas réaliser le boulot qu'on lui demande? On a besoin d'autre chose qui signale que la fonction/opération n'a pas pu se dérouler normalement.

    Avant l'invention des exceptions, la fonction f pouvait retourner un "status" rendant compte de sa bonne exécution: le résultat était à récupérer dans une variable passée par référence. C'est encore cette mécanique là qui est utilisée pour les appels systèmes.

    Son principal défaut étant que si le programmeur oublie de tester le status de retour et récupère un résultat invalide, le code fera ce qu'il pourra jusqu'à ce qu'il plante bien après de la cause de l'erreur...

    Les exceptions, c'est imparable soit on l'attrape (avec un try...except) et on la gère, soit le programme s'arrête. De plus une exception pourra remonter de informations qui permettront d'avoir une idée de la cause et de corriger le problème.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

Discussions similaires

  1. Reprise d'une boucle après une exception
    Par MaInR0 dans le forum PL/SQL
    Réponses: 2
    Dernier message: 22/12/2008, 17h08
  2. Différence entre valeur et valeur boucle+1
    Par jaireimy dans le forum LabVIEW
    Réponses: 5
    Dernier message: 25/11/2008, 17h24
  3. Réponses: 1
    Dernier message: 06/05/2008, 13h32
  4. boucle for avec exception dans l iteration
    Par norachaouia dans le forum Langage
    Réponses: 2
    Dernier message: 19/07/2007, 12h45
  5. Boucle + exception
    Par anis50 dans le forum Oracle
    Réponses: 4
    Dernier message: 13/03/2007, 13h51

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