07

Crear registros con PYTHON y TKINTER [07]

En este tutorial vamos a crear registros con PYTHON y TKINTER siguiendo estos pasos:

  • Agregar etiqueta de mensaje para mostrar el resultado.
  • Validar que el nombre y la clave no esten vacios.
  • Insertar en la base de datos el registro.
  • Refrescar los datos.
Crear registros con PYTHON y TKINTER

Codigo: https://github.com/programadornovato/curso-python-tkinter/commit/ad81ab8b3781a367104bab8c0531154dc64a9bca

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
from tkinter import *
from tkinter import ttk
import mariadb
class Alumno:
def __init__(self,ventana):
self.ventana=ventana
self.ventana.title("Hola mundo")
marco=LabelFrame(self.ventana,text="Alumno")
marco.grid(row=0,column=0,columnspan=3,pady=20)
#Nombre
Label(marco,text="Nombre").grid(row=0,column=0)
self.nombre=Entry(marco)
self.nombre.grid(row=0,column=1)
self.nombre.focus()
#Clave
Label(marco,text="Clave").grid(row=1,column=0)
self.clave=Entry(marco)
self.clave.grid(row=1,column=1)
#Boton
ttk.Button(marco,text="Guardar alumno",command=self.agregarRegistro).grid(row=2,columnspan=2,sticky=W+E)
#Mensaje
self.mensaje=Label(text='',fg='green')
self.mensaje.grid(row=3,column=0,columnspan=2,sticky=W+E)
#Tabla
self.tabla=ttk.Treeview(self.ventana,columns=2)
self.tabla.grid(row=4,column=0,columnspan=2)
self.tabla.heading("#0",text="Nombre",anchor=CENTER)
self.tabla.heading("#1",text="Clave",anchor=CENTER)
def queryAlumnos(self,query):
try:
conn=mariadb.connect(
host="localhost",
user="root",
password="",
database="escuela"
)
except mariadb.Error as e:
print("Error al conectarse a la bd ",e)
cur=conn.cursor()
cur.execute(query)
return cur
def mostrarDatos(self):
registros=self.tabla.get_children()
for registro in registros:
self.tabla.delete(registro)
cur=self.queryAlumnos("SELECT `nombre`,`clave` FROM `alumnos`")
for (nombre,clave) in cur:
self.tabla.insert('',0,text=nombre,values=clave)
def agregarRegistro(self):
if len(self.nombre.get())!=0 and len(self.clave.get())!=0:
query="INSERT INTO `alumnos` (`id`, `nombre`, `clave`) VALUES (NULL, '"+self.nombre.get()+"', '"+self.clave.get()+"');"
self.queryAlumnos(query)
self.mensaje['text']="El alumno "+self.nombre.get()+" se a insertado exitosamente"
self.nombre.delete(0,END)
self.clave.delete(0,END)
self.nombre.focus()
else:
self.mensaje['text']="El nombre y la clave del alumno no pueden estar vacias humano tonto"
self.mostrarDatos()
if __name__=="__main__":
ventana=Tk()
aplicacion=Alumno(ventana)
aplicacion.mostrarDatos()
ventana.mainloop()
from tkinter import * from tkinter import ttk import mariadb class Alumno: def __init__(self,ventana): self.ventana=ventana self.ventana.title("Hola mundo") marco=LabelFrame(self.ventana,text="Alumno") marco.grid(row=0,column=0,columnspan=3,pady=20) #Nombre Label(marco,text="Nombre").grid(row=0,column=0) self.nombre=Entry(marco) self.nombre.grid(row=0,column=1) self.nombre.focus() #Clave Label(marco,text="Clave").grid(row=1,column=0) self.clave=Entry(marco) self.clave.grid(row=1,column=1) #Boton ttk.Button(marco,text="Guardar alumno",command=self.agregarRegistro).grid(row=2,columnspan=2,sticky=W+E) #Mensaje self.mensaje=Label(text='',fg='green') self.mensaje.grid(row=3,column=0,columnspan=2,sticky=W+E) #Tabla self.tabla=ttk.Treeview(self.ventana,columns=2) self.tabla.grid(row=4,column=0,columnspan=2) self.tabla.heading("#0",text="Nombre",anchor=CENTER) self.tabla.heading("#1",text="Clave",anchor=CENTER) def queryAlumnos(self,query): try: conn=mariadb.connect( host="localhost", user="root", password="", database="escuela" ) except mariadb.Error as e: print("Error al conectarse a la bd ",e) cur=conn.cursor() cur.execute(query) return cur def mostrarDatos(self): registros=self.tabla.get_children() for registro in registros: self.tabla.delete(registro) cur=self.queryAlumnos("SELECT `nombre`,`clave` FROM `alumnos`") for (nombre,clave) in cur: self.tabla.insert('',0,text=nombre,values=clave) def agregarRegistro(self): if len(self.nombre.get())!=0 and len(self.clave.get())!=0: query="INSERT INTO `alumnos` (`id`, `nombre`, `clave`) VALUES (NULL, '"+self.nombre.get()+"', '"+self.clave.get()+"');" self.queryAlumnos(query) self.mensaje['text']="El alumno "+self.nombre.get()+" se a insertado exitosamente" self.nombre.delete(0,END) self.clave.delete(0,END) self.nombre.focus() else: self.mensaje['text']="El nombre y la clave del alumno no pueden estar vacias humano tonto" self.mostrarDatos() if __name__=="__main__": ventana=Tk() aplicacion=Alumno(ventana) aplicacion.mostrarDatos() ventana.mainloop()
from tkinter import *
from tkinter import ttk
import mariadb
class Alumno:
    def __init__(self,ventana):
        self.ventana=ventana
        self.ventana.title("Hola mundo")
        marco=LabelFrame(self.ventana,text="Alumno")
        marco.grid(row=0,column=0,columnspan=3,pady=20)
        #Nombre
        Label(marco,text="Nombre").grid(row=0,column=0)
        self.nombre=Entry(marco)
        self.nombre.grid(row=0,column=1)
        self.nombre.focus()
        #Clave
        Label(marco,text="Clave").grid(row=1,column=0)
        self.clave=Entry(marco)
        self.clave.grid(row=1,column=1)
        #Boton
        ttk.Button(marco,text="Guardar alumno",command=self.agregarRegistro).grid(row=2,columnspan=2,sticky=W+E)
        #Mensaje
        self.mensaje=Label(text='',fg='green')
        self.mensaje.grid(row=3,column=0,columnspan=2,sticky=W+E)
        #Tabla
        self.tabla=ttk.Treeview(self.ventana,columns=2)
        self.tabla.grid(row=4,column=0,columnspan=2)
        self.tabla.heading("#0",text="Nombre",anchor=CENTER)
        self.tabla.heading("#1",text="Clave",anchor=CENTER)

    def queryAlumnos(self,query):
        try:
            conn=mariadb.connect(
                host="localhost",
                user="root",
                password="",
                database="escuela"
            )
        except mariadb.Error as e:
            print("Error al conectarse a la bd ",e)
        cur=conn.cursor()
        cur.execute(query)
        return cur
    def mostrarDatos(self):
        registros=self.tabla.get_children()
        for registro in registros:
            self.tabla.delete(registro)
        cur=self.queryAlumnos("SELECT `nombre`,`clave` FROM `alumnos`")
        for (nombre,clave) in cur:
            self.tabla.insert('',0,text=nombre,values=clave)
    def agregarRegistro(self):
        if len(self.nombre.get())!=0 and len(self.clave.get())!=0:
            query="INSERT INTO `alumnos` (`id`, `nombre`, `clave`) VALUES (NULL, '"+self.nombre.get()+"', '"+self.clave.get()+"');"
            self.queryAlumnos(query)
            self.mensaje['text']="El alumno "+self.nombre.get()+" se a insertado exitosamente"
            self.nombre.delete(0,END)
            self.clave.delete(0,END)
            self.nombre.focus()
        else:
            self.mensaje['text']="El nombre y la clave del alumno no pueden estar vacias humano tonto"
        self.mostrarDatos()
if __name__=="__main__":
    ventana=Tk()
    aplicacion=Alumno(ventana)
    aplicacion.mostrarDatos()
    ventana.mainloop()

🎦[CURSO] PYTHON PARA PRINCIPIANTES: https://www.youtube.com/playlist?list=PLCTD_CpMeEKRppvi86Dy8CPYZ8-XzN2qu

Gracias por apoyar este canal: https://www.patreon.com/programadornovato
🔗 Facebook: https://facebook.com/ProgramadorNovatoOficial
🔗 Twitter: https://twitter.com/programadornova
🔗 Linkedin: https://www.linkedin.com/in/programadornovato/
🔗 Instagram: https://www.instagram.com/programadornovato/
🔗 Pagina oficial: https://www.programadornovato.com
🎦 Canal de youtube: https://www.youtube.com/c/programadornovato

<<Anterior tutorial Siguiente tutorial >>

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *