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 :

Python et les variables avec SQLite


Sujet :

Python

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Mars 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2012
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Python et les variables avec SQLite
    Bonjour,

    Je débute en Python et je bloque tout simplement sur une requette SQL:

    LeNom = input("Votre Nom :")

    ensuite j'ouvre la base de donnee, je positionne le curseur et j'entre la requette:

    Query="SELECT * FROM matable WHERE Noms LIKE 'LeNom'%"

    j’exécute et ca plante ...Pour certains cela peut etre evident mais pas pour moi !

    D'avance merci de m'orienter

  2. #2
    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,

    Essaie:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Query="SELECT * FROM matable WHERE Noms LIKE '%s' " % (LeNom,)
    Ou, avec execute:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    curseur.execute("SELECT * FROM matable WHERE Noms LIKE '?' ", (LeNom,))
    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

  3. #3
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    Salut,

    Que veut dire 'ça plante' ? un message d'erreur ?

    Essayes toujours comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    LeNom = input("Votre Nom :")
    obj = (LeNom,)
    c = conn.cursor()
    c.execute('select * from matable where obj=?', obj)
    for row in c:
        print row
    Sans dire que tu as ta solution, bien sur, je ne sais pas comment tu as créé ta base, mais l'idée est là.

    La raison d'utiliser la variable LeNom de cette façon est une question de sécurité.
    Expliquée en détails ici:

    http://docs.python.org/library/sqlit...qlite3#sqlite3

    Pour débuter en python, il y a plus simple que les base de données, remarques.



    Edit: Ha, je ne suis pas le seul insomniaque, je vois.

  4. #4
    Nouveau Candidat au Club
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Mars 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2012
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Merci beaucoup à vous deux ...

    J'ai utilisé cela et cela fonctionne ...
    Query="SELECT * FROM matable WHERE Noms LIKE '%s' " % (LeNom,)
    Malgré que représente ce '%s' et '?' : des expressions régulières ? des wildcards ?
    Je ne suis pas complètement débutant en développement mais la façon de
    passer les variables me dépasse un peu alors que c'est beaucoup plus simple en PHP.

    pourquoi pas:
    Query="SELECT * FROM matable WHERE Noms LIKE" + LeNom + "%"
    Merci ....

  5. #5
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    Citation Envoyé par Paulove Voir le message
    pourquoi pas:
    Query="SELECT * FROM matable WHERE Noms LIKE" + LeNom + "%"
    Merci ....
    C'est exactement ce qui est expliqué dans le lien que je t'ai donné.

Discussions similaires

  1. Réponses: 2
    Dernier message: 28/11/2014, 21h21
  2. Réponses: 0
    Dernier message: 30/10/2014, 19h01
  3. Réponses: 1
    Dernier message: 05/09/2014, 13h54
  4. Récupérer tous les enregistrements avec SQLite
    Par 304bl dans le forum Android
    Réponses: 4
    Dernier message: 04/02/2012, 12h52
  5. Réponses: 4
    Dernier message: 23/06/2009, 16h10

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