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 :

Comment passer des listes à SQLITE


Sujet :

Bibliothèques tierces Python

  1. #1
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Points : 6 789
    Points
    6 789
    Billets dans le blog
    15
    Par défaut Comment passer des listes à SQLITE
    Bonjour à tous,

    Je réalise un petit programme dans lequel l'utilisateur va renseigner un certain nombres de TextCtrl, Chekbox...
    L'HMI de mon programme regroupe ces widgets en catégorie.

    Afin de me simplifier la vie, je souhaite dans une bdd Sqlite non pas passer chacune des valeurs de mes widgets mais des listes de valeurs par catégorie.

    Cette manip m'éviterai d'avoir autant de valeur dans ma bdd qu'il existe de widget.
    Le bu étant ensuite de relire la bdd et de pouvoir retravailler avec les listes.

    Voici un début de ce que j'ai pensé faire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    import sqlite3, os, os.path
     
    connection = sqlite3.connect('local_data/mybdd.db') 
    c = connection.cursor()
    try:
        c.execute('''create table essai(liste1 list, liste2 list)''')
    except: pass
     
    liste_a = ['txt1', 'txt2']
    liste_b = ['txt3', 'txt4']
     
    c.execute("""insert into essai values (liste_a,liste_b)""")
    ...
    J'ai vu sur le site de Sqlite qu'il est possible de convertir le type des arguments que l'on passe à la bdd, mais je ne vois pas bien comment faire.

    Un petit coup de pouce serait le bienvenu.

    D'avance merci
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 281
    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 281
    Points : 36 768
    Points
    36 768
    Par défaut extrait de la doc 'The Python Standard Library'
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    # Never do this -- insecure!
    symbol = 'IBM'
    c.execute("... where symbol = '%s'" % symbol)
     
    # Do this instead
    t = (symbol,)
    c.execute('select * from stocks where symbol=?', t)
     
    # Larger example
    for t in [('2006-03-28', 'BUY', 'IBM', 1000, 45.00),
              ('2006-04-05', 'BUY', 'MSOFT', 1000, 72.00),
              ('2006-04-06', 'SELL', 'IBM', 500, 53.00),
             ]:
        c.execute('insert into stocks values (?,?,?,?,?)', t)
    -W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Points : 6 789
    Points
    6 789
    Billets dans le blog
    15
    Par défaut
    J'avais effectivement vu cet exemple, mais je n'y avais pas pensé.

    Merci beaucoup

    @+

    EDIT:

    Je viens de faire l'essai du code ci-dessus. En fait je pense qu'il ne correspond pas à ma demande. Je pense que je n'ai pas été assez clair.

    Voici expliqué d'une autre manière ce que je souhaite faire.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    import sqlite3
     
    list_a = ['essai1', 'essai2']
    list_b = ['essai3', 'essai4']
     
    connection = sqlite3.connect('local_data/mybdd.db') 
     
    c = connection.cursor()
    c.execute('''create table stocks(liste1, liste2)''') # je crée ma bdd à deux champs.
     
    c.execute("""insert into stocks values """(liste_a,liste_b) #je rentre mes listes dans chacun des champs.
     
    ... #ensuite je veux pouvoir récupérer ces listes, sous forme de listes afin de pouvoir réutiliser chacune des variables de celles-ci
    Le code donné avant permets pour chaque liste de distribuer chacune des variables dans les champs correspondant. C'est pas vraiment ça que je veux.
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 281
    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 281
    Points : 36 768
    Points
    36 768
    Par défaut ah oui...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    # Larger example
    for t in [('2006-03-28', 'BUY', 'IBM', 1000, 45.00),
              ('2006-04-05', 'BUY', 'MSOFT', 1000, 72.00),
              ('2006-04-06', 'SELL', 'IBM', 500, 53.00),
             ]:
        c.execute('insert into stocks values (?,?,?,?,?)', t)
    <=>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
        c.executemany('insert into stocks values (?,?,?,?,?)', 
             [('2006-03-28', 'BUY', 'IBM', 1000, 45.00),
              ('2006-04-05', 'BUY', 'MSOFT', 1000, 72.00),
              ('2006-04-06', 'SELL', 'IBM', 500, 53.00),
             ])
    -W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  5. #5
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Points : 6 789
    Points
    6 789
    Billets dans le blog
    15
    Par défaut
    Après avoir lacher un peu ce problème je me repenche dessus et malheureusement tourne en rond...

    J'ai revu un peu mon souhait et en réalté ce que je souhaite faire c'est ça:

    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
     
    import sqlite3
     
    list = [1,'2']
     
    def new_bdd(data):
        connection = sqlite3.connect('my_bdd.db') 
        c = connection.cursor()
     
        c.execute('''create table essai(pos1, pos2)''')
        c.execute('''insert into essai values (data[0],data[1])''')
     
        connection.commit()
        c.close()
        connection.close()
     
    new_bdd(list)
    Mais ce code me retourne l'erreur suivante:
    sqlite3.OperationalError: near "[0]": syntax error
    Un petit coup de main serait le bienvenu car là je commence à plus avoir de cheveuxx...


    Bonne nuit à tous et merci d'avance
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

  6. #6
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 281
    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 281
    Points : 36 768
    Points
    36 768
    Par défaut
    Essayez plutôt:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    insert_string= 'INSERT INTO essai (pos1, pos2) VALUES (%s, %s)'
    c.execute(insert_string, (data[0],data[1]))
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    c.executemany(insert_string, rows)
    avec rows de la forme liste de uplets ou de listes.

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

  7. #7
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Points : 6 789
    Points
    6 789
    Billets dans le blog
    15
    Par défaut
    J'ai eu une vision en me levant ce matin...
    Au lieu de casser les c******s à mes amis de Déveleppez.com en essayant de faire un truc qui parait un peu galère (vouloir passer une liste dans une BDD), pourquoi ne pas passer plutôt un tuple comme dans l'exemple donné.

    Ca donnerai un truc du genre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    ...
    tuple1 = ('r','coucou')
    data = [tuple1]
     
    c.execute('''create table essai(pos1, pos2)''')
    for t in data:
     
        c.execute('insert into essai values (?,?)', t)
    connection.commit()
    c.close()
    connection.close()
    Aaaaahhhhhhhhh Bétise et entêtement quand vous nous tenez...

    Merci pour toute ton aide wiztricks.

    A bientôt
    Initiation à Qt Quick et QML : Partie 1 - Partie 2
    En cas de besoin, pensez à la
    Mon site et mes tutoriaux sur Developpez.com
    Pas de question technique par MP... Les forums sont là pour ça

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

Discussions similaires

  1. Comment passer des paramètre a OpenRecordset
    Par molarisapa dans le forum Access
    Réponses: 2
    Dernier message: 09/03/2006, 17h14
  2. Comment passer des argument a un script php ?
    Par Florina dans le forum Linux
    Réponses: 2
    Dernier message: 11/12/2005, 14h38
  3. [script SQL]comment passer des parametres a un scrip sql?
    Par la7su dans le forum Langage SQL
    Réponses: 5
    Dernier message: 23/03/2005, 10h55
  4. Réponses: 7
    Dernier message: 30/12/2004, 12h01

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