"email.iterators": Iterators
****************************

**Code source :** Lib/email/iterators.py

======================================================================

Itérer sur l'arborescence d'un objet message est plutôt simple avec la
méthode "Message.walk". Le module "email.iterators" fournit des
fonctionnalités d'itérations de plus haut niveau sur les arbres
d'objets messages.

email.iterators.body_line_iterator(msg, decode=False)

   Cette fonction permet d'itérer sur tous les contenus de tous les
   éléments de *msg*, en retournant les contenus sous forme de chaînes
   de caractères ligne par ligne. Il saute les entêtes des sous
   éléments, et tous les sous éléments dont le contenu n'est pas une
   chaîne de caractères Python. C'est en quelque sorte équivalent à
   une lecture plate d'une représentation textuelle du message à
   partir d'un fichier en utilisant "readline()", et en sautant toutes
   les entêtes intermédiaires.

   Le paramètre optionnel *decode* est transmis à la méthode
   "Message.get_payload".

email.iterators.typed_subpart_iterator(msg, maintype='text', subtype=None)

   Cette fonction permet d'itérer sur tous les sous éléments de *msg*,
   en retournant seulement les sous éléments qui correspondent au type
   MIME spécifié par *maintype* et *subtype*.

   Notez que le paramètre *subtype* est optionnel ; s'il n'est pas
   présent, alors le type MIME du sous élément est seulement composé
   du type principal. *maintype* est également optionnel ; sa valeur
   par défaut est *text*.

   En conséquence, par défaut, "typed_subpart_iterator()" retourne
   chaque sous élément qui a un type MIME de type *text/**.

La fonction suivante a été ajouté en tant qu'un outil de débogage.
Elle *ne devrait pas* être considérée comme une interface publique
supportée pour ce paquet.

email.iterators._structure(msg, fp=None, level=0, include_default=False)

   Affiche une représentation indentée des types de contenu de la
   structure de l'objet message. Par exemple :

      >>> msg = email.message_from_file(somefile)
      >>> _structure(msg)
      multipart/mixed
          text/plain
          text/plain
          multipart/digest
              message/rfc822
                  text/plain
              message/rfc822
                  text/plain
              message/rfc822
                  text/plain
              message/rfc822
                  text/plain
              message/rfc822
                  text/plain
          text/plain

   Le paramètre optionnel *fp* est un objet fichier-compatible dans
   lequel on peut écrire le flux de sortie. Il doit être approprié
   pour la fonction de Python "print()". *level* est utilisé en
   interne. *include_default*, si vrai, affiche aussi le type par
   défaut.
