Tkinter problème de commande
Résolu
kymer_officiel
Messages postés
38
Date d'inscription
Statut
Membre
Dernière intervention
-
Phil_1857 Messages postés 1872 Date d'inscription Statut Membre Dernière intervention -
Phil_1857 Messages postés 1872 Date d'inscription Statut Membre Dernière intervention -
Bonjour,
J’ai un programme en tkinter et sqlite3 et le probleme c que ma commande ne s’exécute pas et je compre,d pas pourquoi. Quelqu’un pourrait m’aidez s’il vous plaît ?
J’ai un programme en tkinter et sqlite3 et le probleme c que ma commande ne s’exécute pas et je compre,d pas pourquoi. Quelqu’un pourrait m’aidez s’il vous plaît ?
import sqlite3 from tkinter import * fenetre1= Tk() fenetre1.geometry("380x380+500+200") fenetre1.resizable(width=NO,height=NO) Etiquette1=Label(fenetre1,text='Prénom').place(x=100,y=45) entree1=Entry(fenetre1,width=10) entree1.insert(0,1) entree1.place(x=100,y=65) Etiquette2=Label(fenetre1,text='Age').place(x=200,y=45) entree2=Entry(fenetre1,width=10) entree2.insert(0,1) entree2.place(x=200,y=65) conn = sqlite3.connect('baseDonnees.db') cursor = conn.cursor() cursor.execute("""CREATE TABLE IF NOT EXISTS users(id INTEGER PRIMARY KEY AUTOINCREMENT UNIQUE,name TEXT,age INTEGER)""") conn.commit() p = Etiquette1 a = Etiquette2 def Creation(): cursor.execute("""INSERT INTO users(name, age) VALUES(?, ?)""", (p, a)) conn.commit() bouton1=Button(fenetre1,text='crée un nouveau compte',command=Creation) bouton1.place(x=150,y=300) #Affichage du contenu de la BDD print('\nContenu : ') cursor.execute('select * from users') for records in cursor: for k in range (len(records)): print(records[k], end = ' ') cursor.close() conn.close() fenetre1.mainloop()
Configuration: iPad / Chrome 77.0.3865.103
A voir également:
- Tkinter problème de commande
- Invite de commande - Guide
- Commande terminal mac - Guide
- Commande dism - Guide
- Diskpart commande - Guide
- Commande scannow - Guide
6 réponses
Bonjour Kymer,
OK, d'autant que tu avais déjà résolu le problème en mode console
Avec interface graphique, c'est différent, il faut tenir compte de la gestion des évènements
Ce que tu fait dans ton code tel qu'il est actuellement :
1_ Tu crée une fenêtre avec un Label "prénom" et une Entry pour le saisir, et un Label "age" et
une autre Entry pour le saisir
2_ Tu initialise les 2 Entry avec le chiffre 1
3_ Tu crée un bouton pour créer un compte
4_ Ensuite, tu crée la base de données, tu crois que tu récupères p et a:
mais, je te l'ai dit, ce n'est pas comme ça
5_ ensuite tu fermes la connexion à la base de données
6_ quand on clique le bouton, on appelle Creation() qui est censée insérer p et a dans la base,
mais la connexion est déjà fermée ! (point 5 ci -dessus)
OK, d'autant que tu avais déjà résolu le problème en mode console
Avec interface graphique, c'est différent, il faut tenir compte de la gestion des évènements
Ce que tu fait dans ton code tel qu'il est actuellement :
1_ Tu crée une fenêtre avec un Label "prénom" et une Entry pour le saisir, et un Label "age" et
une autre Entry pour le saisir
2_ Tu initialise les 2 Entry avec le chiffre 1
3_ Tu crée un bouton pour créer un compte
4_ Ensuite, tu crée la base de données, tu crois que tu récupères p et a:
p = Etiquette1 a = Etiquette2
mais, je te l'ai dit, ce n'est pas comme ça
5_ ensuite tu fermes la connexion à la base de données
6_ quand on clique le bouton, on appelle Creation() qui est censée insérer p et a dans la base,
mais la connexion est déjà fermée ! (point 5 ci -dessus)
Bonjour,
A mon avis, quand on appuie sur le bouton 'crée un nouveau compte' qui lance la fonction
Creation(), la connexion à la BDD est déjà close et donc cursor.execute
ne peut pas se faire...
De plus pour récupérer le contenu des entry, il ne suffit pas de faire:
p = Etiquette1
il existe une méthode Python pour ça
A mon avis, quand on appuie sur le bouton 'crée un nouveau compte' qui lance la fonction
Creation(), la connexion à la BDD est déjà close et donc cursor.execute
ne peut pas se faire...
De plus pour récupérer le contenu des entry, il ne suffit pas de faire:
p = Etiquette1
il existe une méthode Python pour ça
Bonjour,
de plus, c'est le contenu de entree1 et entree2 que tu veux récupérer
pas celui de Etiquette1, Etiquette2 ...
de plus, c'est le contenu de entree1 et entree2 que tu veux récupérer
pas celui de Etiquette1, Etiquette2 ...
Bonjour Kymer,
Alors as-tu résolu le problème ?
Alors as-tu résolu le problème ?
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
bonjour,
D'accord je vois se que tu veux dire, et j'ai réussi.
voici mon code
D'accord je vois se que tu veux dire, et j'ai réussi.
voici mon code
import sqlite3 from tkinter import * fenetre1= Tk() fenetre1.geometry("380x380+500+200") fenetre1.resizable(width=NO,height=NO) Etiquette1=Label(fenetre1,text='Prénom').place(x=100,y=45) entree1=Entry(fenetre1,width=10) entree1.insert(0,1) entree1.place(x=100,y=65) Etiquette2=Label(fenetre1,text='Age').place(x=200,y=45) entree2=Entry(fenetre1,width=10) entree2.insert(0,1) entree2.place(x=200,y=65) """p = entree1.get() a = entree2.get()""" def Creation(): p = entree1.get() a = entree2.get() conn = sqlite3.connect('baseDonnees.db') cursor = conn.cursor() cursor.execute("""CREATE TABLE IF NOT EXISTS users(id INTEGER PRIMARY KEY AUTOINCREMENT UNIQUE,name TEXT,age INTEGER)""") conn.commit() cursor.execute("""INSERT INTO users(name, age) VALUES(?, ?)""", (p, a)) conn.commit() cursor.close() conn.close() bouton1=Button(fenetre1,text='crée un nouveau compte',command=Creation) bouton1.place(x=150,y=300) fenetre1.mainloop()
Hola Kymer,
Dans ta fonction, tu refait la création de la table à chaque fois
Moi, je fait plutôt comme ça:
Dans ta fonction, tu refait la création de la table à chaque fois
Moi, je fait plutôt comme ça:
import sqlite3 from tkinter import * conn = sqlite3.connect('baseDonnees.db') cursor = conn.cursor() cursor.execute("""CREATE TABLE IF NOT EXISTS users(id INTEGER PRIMARY KEY AUTOINCREMENT UNIQUE,name TEXT,age INTEGER)""") conn.commit() def Creation(): a = entree2.get() p = entree1.get() cursor.execute("""INSERT INTO users(name, age) VALUES(?, ?)""", (p, a)) conn.commit() #Affichage du contenu de la BDD cursor.execute('select * from users') for records in cursor: for k in range (len(records)): print(records[k], end = ' ') print('\n') def quitter(): cursor.close() conn.close() fenetre1.quit() fenetre1= Tk() fenetre1.geometry("380x200+500+200") fenetre1.title('Base de données') menubar = Menu(fenetre1) filemenu = Menu(menubar, tearoff=0) menubar.add_cascade(label="Fichier", menu=filemenu) filemenu.add_command(label="Quitter", command=quitter) fenetre1.config(menu=menubar) Label(fenetre1,text='Prénom').place(x=100,y=45) entree1=Entry(fenetre1,width=10) entree1.place(x=100,y=65) entree1.focus() Label(fenetre1,text='Age').place(x=200,y=45) entree2=Entry(fenetre1,width=10) entree2.place(x=200,y=65) bouton1=Button(fenetre1,text='Créer un nouveau compte',command=Creation) bouton1.place(x=100,y=100) fenetre1.mainloop()