[Python]Encodage du Rich Text

Résolu
teebo Messages postés 33585 Date d'inscription   Statut Contributeur Dernière intervention   -  
teebo Messages postés 33585 Date d'inscription   Statut Contributeur Dernière intervention   -
Salut tout le monde...

J'ai fait un script qui me génère un rapport de mes tâches d'outlook, mlaheureusement, dans le champ "Body" qui contient le texte même des mes tâches, on trouve de drôles de caractères: üäößµâéèëœç etc...

Et sans doute des trucs pas très pythoniques non plus puisque je fais du drag-drop de excel ou word dans mes tâches (genre au niveau des remplissages de ligne)

Bref

Quand j'essaye d'encoder ça en latin-1, python y perd le sien, je me retrouve donc à encoder ça en utf-8, ce qui me donne de jolis trucs comme:

Könntest du das so schnell wie möglich klären bitte?


à la place de

Könntest du das so schnell wie möglich klären bitte?


ou alors des suites de
                                                   


Je suis donc preneur de bonnes idées en la matière qui me permettrait d'avoir un truc un peu plus joli à l'arrivée

Merci

--
-Il a pas l'air terrible !
-Faut pas s'y fier, car personne n'en est ressorti ! [...]Faut dire aussi que personne y est entré

7 réponses

  1. kilian Messages postés 8675 Date d'inscription   Statut Modérateur Dernière intervention   1 526
     
    Pour l'allemand ce ne serait pas plutôt latin-2 (iso-8859-2)?
    http://alis.isoc.org/codage/iso8859/jeuxiso.htm#ISO-8859-2
    0
  2. teebo Messages postés 33585 Date d'inscription   Statut Contributeur Dernière intervention   1 797
     
    Tout d'abord merci...

    mais non, toujours:
    UnicodeEncodeError: 'ascii' codec can't encode character u'\xe9' in position 641: ordinal not in range(128)


    et ne me demande pas pourquoi il dit "ascii" :(
    0
  3. teebo Messages postés 33585 Date d'inscription   Statut Contributeur Dernière intervention   1 797
     
    Bon manifestement c'est le rich text qui plante, j'ai réussi à limiter la casse à 2 tâches avec un try/except mais j'aimerai bien que ça marche tout le temps correctement quand même.

    Je pense que ça vient des retours à la ligne mais je ne sais pas comment vérifier ça simplement ni surtout comment corriger.
    0
  4. teebo Messages postés 33585 Date d'inscription   Statut Contributeur Dernière intervention   1 797
     
    Arg, nouvelle évolution, apparement c'est un type d'apostrophe simple...
    Plus précisément le ’ de l'UTF8...enfin c'est ce qu'il affiche...
    0
  5. Vous n’avez pas trouvé la réponse que vous recherchez ?

    Posez votre question
  6. teebo Messages postés 33585 Date d'inscription   Statut Contributeur Dernière intervention   1 797
     
    Arg, qu'il est con le teebo.

    En fait il suffit de faire montruc.encode("latin-1","ignore")
    Il me vire les apostrophes et tirets non conforme mais c'est acceptable dans l'ensemble il n'y en a pas tant que ça, et je garde même les accents les ß et autres üäö

    C'est beau Python mais ça manque d'intelisense notamment pour les fonctions surchargées :)
    0
    1. kilian Messages postés 8675 Date d'inscription   Statut Modérateur Dernière intervention   1 526
       
      C'est beau Python mais ça manque d'intelisense notamment pour les fonctions surchargées :)

      Pourquoi?
      0
      1. teebo Messages postés 33585 Date d'inscription   Statut Contributeur Dernière intervention   1 797 > kilian Messages postés 8675 Date d'inscription   Statut Modérateur Dernière intervention  
         
        Ben ça m'aurait permis de voir que j'avais une surcharge qui prenait un paramètre qui pouvait être "ignore" :)
        0
      2. kilian Messages postés 8675 Date d'inscription   Statut Modérateur Dernière intervention   1 526 > kilian Messages postés 8675 Date d'inscription   Statut Modérateur Dernière intervention  
         
        Ah ben ça ya qu'un IDE qui aurait pu te le dire tout de suite :-)

        Mais en fait je crois qu'il n'y a pas de methode encode qui ne prenne qu'un paramètre. Si?
        0
      3. teebo Messages postés 33585 Date d'inscription   Statut Contributeur Dernière intervention   1 797 > kilian Messages postés 8675 Date d'inscription   Statut Modérateur Dernière intervention  
         
        Si :)

        Et j'utilisais Pythonwin IDE

        Et il ne me le disait pas...

        :-P
        0
      4. kilian Messages postés 8675 Date d'inscription   Statut Modérateur Dernière intervention   1 526 > kilian Messages postés 8675 Date d'inscription   Statut Modérateur Dernière intervention  
         
        Ah ok, ben d'accord alors :-)
        0
  7. choubaka Messages postés 5534 Date d'inscription   Statut Modérateur Dernière intervention   2 113
     
    99% des problèmes se situent entre le clavier et le dossier du siège ..

    CQFD
    0
  8. sebsauvage Messages postés 33284 Date d'inscription   Statut Modérateur Dernière intervention   15 684
     
    Pas tout lu, teebo, mais si ça peut aider:

    https://sebsauvage.net/python/charsets_et_encoding.html
    0
    1. teebo Messages postés 33585 Date d'inscription   Statut Contributeur Dernière intervention   1 797
       
      Arf oui, ça aurait aidé puisque je ne savais pas que le encode pouvait prendre une deuxième paramètre (sauf que les caractères me prenant la tête étant des ' j'ai choisis "ignore" à la place de ton "replace").

      Merci quand même :)
      0