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

Réseau/Web Python Discussion :

Explication sur sqlite3 et python


Sujet :

Réseau/Web Python

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mai 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : Maroc

    Informations forums :
    Inscription : Mai 2012
    Messages : 15
    Points : 7
    Points
    7
    Par défaut Explication sur sqlite3 et python
    salut,

    pour quoi quand je veux faire un UPDATE ou INSERT dans une fonction et je retourne une réponse pour l'afficher il me donne erreur???

    merci

    la fonction:
    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
    def Modifier_pass(self,login,l_pass,n_pass,r_n_pass):
                    if self.verifier:
                            n_pass_h=md5(n_pass).hexdigest()
                            l_pass_h=md5(l_pass).hexdigest()
                            r_n_pass_h=md5(r_n_pass).hexdigest()
     
                            if n_pass_h!=r_n_pass_h:
                                    return "Retaper votre mot de passe"
                            else:
                                    if login!=self.Get_login():
                                            return "Login est incorrect"
                                    else:
                                            if l_pass_h!=self.Get_password():
                                                    return "L'ancien mot de passe est incorrect"
                                            else:
                                                    if self.Get_profil()=='Admin':
                                                            if Test_Pass(login,n_pass)!='p0':
                                                                    return reponse(Test_Pass(login,n_pass))
                                                            else:
                                                                    self.cursor.execute('UPDATE Comptes SET password=? WHERE login=?',(n_pass_h,login,))
                                                                    self.connection.commit()
                                                                    return "le mot de passe a été mis à jour avec succès"
                                                    else:
                                                            if Test_Pass(login,n_pass)!='p0':
                                                                    return reponse(Test_Pass(login,n_pass))
                                                            else:
                                                                    self.cursor.execute('UPDATE Comptes SET password=? WHERE login=?',(n_pass_h,login,))
                                                                    self.connection.commit()
                                                                    Modifier_Pass(login,n_pass)
                                                                    return "le mot de passe a été mis à jour avec succès"
                    else:
                            return 0

    l'appel du fonction:
    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
    #! /usr/bin/python
    # -*- coding: utf-8 -*-
     
    import sys, cgi
    from Base import *
    import Cookie
     
     
    form = cgi.FieldStorage()
    login=form.getvalue('login')
    l_pass=form.getvalue('l_pass')
    n_pass=form.getvalue('n_pass')
    r_n_pass=form.getvalue('r_n_pass')
     
    C=Cookie.SimpleCookie(os.environ['HTTP_COOKIE'])
    user=C["user"].value
    password=C["password"].value
     
    a=DBOAB('OAB.db')
     
    a.Authentification(user,password)
    rep=a.Modifier_pass(login,l_pass,n_pass,r_n_pass)
    print "Content-type:text/html\r\n\r\n"
    if a.verifier:
            print rep
    else:
            print 'non'

  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
    Si vous ne donnez pas l'erreur remontée ni un code permettant de la reproduire, que voulez vous qu'on réponde?
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Expert éminent
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 461
    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 461
    Points : 9 248
    Points
    9 248
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Je viens d'essayer avec update, et effectivement, ça ne renvoie pas le nombre de lignes modifiées comme certains serveurs le font. Sqlite3 est très pratique et très performant, mais ne respecte que le SQL1992.

    Il ne reste plus qu'à faire un 'select' avec un count(*) et le même where que pour l'update, et on a l'info.

    Par exemple si on a:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    curseur.execute("""update codes set code='btrx' where code='btr' """)
    On a le nombre de lignes modifiées avec:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    curseur.execute("""select count(*) from codes where code='btr' """)
    nblignes = curseur.fetchone()[0]
    Comme sqlite est très rapide, ça ne devrait pas se sentir...
    Un expert est une personne qui a fait toutes les erreurs qui peuvent être faites, dans un domaine étroit... (Niels Bohr)
    Mes recettes python: http://www.jpvweb.com

  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
    Citation Envoyé par tyrtamos Voir le message
    Je viens d'essayer avec update, et effectivement, ça ne renvoie pas le nombre de lignes modifiées comme certains serveurs le font. Sqlite3 est très pratique et très performant, mais ne respecte que le SQL1992.
    sqlite3 fait ce qu'il peut avec les standards SQL.
    Côté Python, tant que le module correspondant respecte la DBAPI (de Python) çà me va bien... car l'info dans remonte dans cursor.rowcount.
    Voir gribouillage ci dessous:

    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
    import sqlite3
    from contextlib import closing
     
    def show_records(cnx, state):
       sql = """select * from test where state = :state"""
       with closing(cnx.cursor()) as c:
           c.execute(sql, vars())
           rows = c.fetchall()
       print ('state: %s, count= %d' % (state, len(rows)))  
     
    def update_records(cnx, value, state):
        sql = "update test set value = :value where state = :state"
        with closing(cnx.cursor()) as c:
            c.execute(sql, vars())
            print ('state: %s, updated: %d' % (state, c.rowcount))
     
    if __name__ == '__main__':
        import random
     
        ddl = """create table test(
               name text primary key,
               state text,
               value integer default 1)"""
     
        cnx = sqlite3.connect(':memory:')
        cnx.execute(ddl)
     
        COUNT = 10
        STATES = ('a', 'b', 'c', 'd')
        records = [ ('ident-%d' % x, random.choice(STATES)) for x in range(COUNT) ]
        cnx.executemany('insert into test (name, state) values (:name, :state)', records)
     
        show_records(cnx, 'a')
        update_records(cnx, 2, 'a')
        show_records(cnx, 'a')
     
        show_records(cnx, 'x')
        update_records(cnx, 2, 'x')
    En sortie çà donne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    state: a, count= 4
    state: a, updated: 4
    state: a, count= 4
    state: x, count= 0
    state: x, updated: 0
    Ceci dit le PO parle de remontée d'une erreur (traduire exception?) et comme il ne teste pas le retour des appels à .execute je ne suis pas certain que cette digression l'aide beaucoup.
    Enfin on verra bien.
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

Discussions similaires

  1. Besoin d'explication sur un programme en Python 3
    Par THESO dans le forum Général Python
    Réponses: 3
    Dernier message: 05/03/2014, 09h54
  2. Besoin d'explications sur float et l'élasticité !
    Par KneXtasY dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 14/01/2005, 15h15
  3. s.v.p :explication sur le ".h" et dll de l'opengl
    Par Asmod_D dans le forum OpenGL
    Réponses: 1
    Dernier message: 22/11/2004, 10h32
  4. Réponses: 28
    Dernier message: 18/08/2003, 11h54
  5. recherches des cours ou des explications sur les algorithmes
    Par Marcus2211 dans le forum Algorithmes et structures de données
    Réponses: 6
    Dernier message: 19/05/2002, 22h18

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