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 :

mysql.connector Problème bytearray() le même scripte mais le resultat different


Sujet :

Python

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2011
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2011
    Messages : 31
    Points : 30
    Points
    30
    Par défaut mysql.connector Problème bytearray() le même scripte mais le resultat different
    Bonjour, j'ai un probleme de codage avec le mysql.connector.2.0.3
    lle cursor de mysql.connector renvoi un tuble de type bytearray(ok c bon je le decoder avec decode("utf-8")), mais l'orsque je execute mon projet depuis un autre pc qui a le meme version logiciels(Python , Mysql et mysql.connector2.0.3) il me renvoi un tuble de type Str, et il m'affiche un problème que le type str n'a pas un attribut decode("utf-8")(cette probleme est resolue quand j'ai illuminer le decode("Utf-8") ). Alors j'aime bien savoir l’origine de cette problème et savoir une solution pour me donne le mème resulta sur le deux PC.
    les deuc pc on le meme verion logiciels(windows7 64bit, python4.3.2, mysql 5.6.17(encodeage 'Utf-8'), mysql.connector 2.0.3).
    voila mon script
    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    # -*- coding: Utf-8 -*-
    from tkinter import *
    from tkinter.ttk import *
    import mysql.connector
     
    class consulter(Frame):
        def __init__(self, parent):
            Frame.__init__(self, parent)   
     
            self.parent = parent
     
            self.initUI()
     
        def initUI(self):
            self.pack()
            db = mysql.connector.connect(host="localhost",user="root",password="",database="stock")
            cursor = db.cursor()
            cursor.execute("SELECT * FROM produit")
            results = cursor.fetchall()
            sb = Scrollbar(self, orient=VERTICAL)
            sb.pack(side=RIGHT, fill=Y)
            lbox=Treeview(self,yscrollcommand=sb.set)
            sb.configure(command=lbox.yview)
     
            lbox['columns']=("a","b","c","d")
            lbox.column("#0", anchor="w",width=50)
            lbox.heading("#0", text='Num')
            lbox.heading("a",text="Code")
            lbox.column("a",minwidth=100,width=100)
            lbox.heading("b", text="Nom")
            lbox.column("b",minwidth=100,width=200)
            lbox.heading("c", text="Quantité")
            lbox.column("c",minwidth=0,width=100)
            lbox.heading("d", text="Prix")
            lbox.column("d",minwidth=100,width=100)
            i=1
            for r in results:
                lbox.insert("","end",0,text=i,values=(r))
                i+=1
            lbox.pack()
     
            db.close()

  2. #2
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2011
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2011
    Messages : 31
    Points : 30
    Points
    30
    Par défaut
    Voila une petite illustration:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    results = cursor.fetchone()
            print(results)
    cette parite de code donne deux résultat différents:
    l'ors je l'execute surle premier pc affiche: (bytearray(b'l30'), bytearray(b'test'), 0, 23.0)
    Et pour le 2eme pc affiche:(l30, test, 0, 23.0)
    Note Bien que les Deux Pcs en le même environnement(Mysql et python et mysql.connector)...
    y ail une explication pour cette phénomène bizarre?
    Merci d'avance pour Vos aides.

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

    Essayez de préciser charset et encoding souhaité lors du connect.

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

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2011
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2011
    Messages : 31
    Points : 30
    Points
    30
    Par défaut
    salut wiztricks ,
    oui j'ai essayé de préciser l'option charset du connect, mais c'est rien, et j'ai bien réglé l'encodage de deux SGBD mysql sur les deux PCs.
    pour avancé au mon projet j'ai changé a utiliser MySQLdb ou Pymysql. Mais il faut savoir l'origine de cette problème, puisque nous somme des programmeurs

Discussions similaires

  1. [ODBC MYSQL Connector] Problème de configuration
    Par GarsDuCalvados dans le forum MySQL
    Réponses: 2
    Dernier message: 09/06/2009, 19h45
  2. Problème d'installation de MySql connector ODBC
    Par developppez dans le forum Windows Forms
    Réponses: 1
    Dernier message: 27/12/2008, 11h26
  3. MySQL et VS2005 problème avec MySQL connector 5.1
    Par AkH dans le forum Accès aux données
    Réponses: 1
    Dernier message: 29/07/2007, 23h28
  4. [MySQL] Tout en UTF8 mais problème accentuations quand même
    Par speedev dans le forum PHP & Base de données
    Réponses: 10
    Dernier message: 11/04/2007, 22h43
  5. [MySQL] problème avec deux requetes dans un même script
    Par leclone dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 09/02/2007, 10h28

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