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

Bibliothèques tierces Python Discussion :

Erreur sqlalchemy lettre accentuée


Sujet :

Bibliothèques tierces Python

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    62
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 62
    Points : 39
    Points
    39
    Par défaut Erreur sqlalchemy lettre accentuée
    Bonjour,

    J'ai cette erreur qui survient à chaque appel de mes requêtes :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    D:\Python26\lib\site-packages\sqlalchemy-0.7.3-py2.6.egg\sqlalchemy\engine\default.py:453: SAWarning: Unicode type received non-unicode bind param value
    param.append(processors[key](compiled_params[key]))
    Mes requêtes s'exécute bien si dans ma base il n'y a pas de lettre accentuée.

    Sa viendrais qu'elixir/sqlalchemy est en ASCII. savez-vous quel est le parametrage d'elixir/sqlalchemy pour qu'il soit en utf8 ?

    Je pense que c'est un paramètre qu'il faut écrire lors de la connection à la base.

    Cordialement

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 283
    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 283
    Points : 36 770
    Points
    36 770
    Par défaut
    Salut,

    client encoding est un paramètre de la connexion à passer dans la construction de l'engine (ou de la metadata). Sa formulation dépend du type de la BDD voire du driver.

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

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    62
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 62
    Points : 39
    Points
    39
    Par défaut
    J'utilise une BDD de type Mysql, j'ai formulé ma connexion comme suite sachant que j'utilise elixir:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    metadata.bind = "mysql://user:mdp@host/nomBDD"
    using_options_defaults(shortnames=True, convert_unicode=True, encoding="utf8")
    Mais rien ny fait ma BDD est bien créer, mais le warning est toujours là et du coup pas de possibilité de lire ou d'inserer des lettres accentuées.

    si vous avez l'écriture exacte de la connexion je suis preneuse.
    Merci

    Cordialement

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 283
    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 283
    Points : 36 770
    Points
    36 770
    Par défaut
    Salut,

    Elixir est quelque peu devenu obsolete depuis que SQLAlchemy a intégré une interface declarative.
    MySQL est la BDD et non le driver DBAPI installé côté Python pour travailler avec.

    Dans la documentation du dialect MySQL, vous trouverez la façon de préciser "utf-8" en utilisant charset et use_unicode pour les différents "drivers".

    Bon courage,

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

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    62
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 62
    Points : 39
    Points
    39
    Par défaut
    Bonjour wiztricks,

    J'avais bien lu cette doc et passée ma connection ainsi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    metadata.bind = "mysql://user:mdp@host/nomBDD"charset=utf8&use_unicode=0
    using_options_defaults(shortnames=True, convert_unicode=True, encoding="utf8")
    pas de résultat. Est ce que chaque class doit avoir le paramètre charset et unicode??
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    class Document_Hermione(Document, charset=utf8, unicode=0 ??):
        using_options(inheritance='multi', tablename = "Document_Hermione")
        Commentaire_DocH = Field (Unicode(255), nullable = False)
        BoolDocM = Field (Boolean, nullable = False)
        TypeDoc = ManyToOne ("Type_Doc")
        Attribution = OneToMany("Attribution")
        Nature = ManyToOne ("Nature_Doc")
        Etat = ManyToOne ("Etat_Doc")
        DocV=OneToMany("Doc_Version")

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

Discussions similaires

  1. [MySQL] preg_match erreur découpage dernière lettre accentuée
    Par pixworld2 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 17/02/2011, 14h07
  2. Réponses: 6
    Dernier message: 12/12/2006, 11h27
  3. Récupération des lettres accentuées
    Par troumad dans le forum Installation
    Réponses: 5
    Dernier message: 15/11/2005, 21h28
  4. HashCode avec lettres accentuées...
    Par Kineas dans le forum C++
    Réponses: 4
    Dernier message: 08/04/2005, 10h54
  5. Comment entrer des lettres accentuées sous postgresql ?
    Par Chihuahua dans le forum Requêtes
    Réponses: 11
    Dernier message: 28/08/2003, 08h04

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