Buscar registros con PYTHON y TKINTER [10]

Que haremos en este tutorial:

  • Crear Entry buscarNombre, buscarClave y botón buscar.
  • Crear la función buscarRegistro.
  • Si encuentra texto en el buscarNombre y/o en la buscarClave busca por uno o ambos parámetros en caso contrario muestra todos los registros.

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

from tkinter import *
from tkinter import ttk
from tkinter import messagebox
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
        self.crear=Button(marco,text="Crear alumno",command=self.agregarRegistro,bg="green",fg="white")
        self.crear.grid(row=2,columnspan=2,sticky=W+E)
        self.editar=Button(marco,text="Editar alumno",command=self.editarRegistro,bg="yellow")
        self.editar.grid(row=3,columnspan=2,sticky=W+E)
        self.editar["state"]="disabled"
        self.borrar=Button(marco,text="Borrar alumno",command=self.borrarRegistro,bg="red",fg="white")
        self.borrar.grid(row=4,columnspan=2,sticky=W+E)
        self.borrar["state"]="disabled"

        #Mensaje
        self.mensaje=Label(text='',fg='green')
        self.mensaje.grid(row=5,column=0,columnspan=2,sticky=W+E)
        #Buscar nombre
        Label(self.ventana,text="Buscar nombre").grid(row=6,column=0)
        self.buscarNombre=Entry(self.ventana)
        self.buscarNombre.grid(row=6,column=1)
        #Clave
        Label(self.ventana,text="buscar clave").grid(row=7,column=0)
        self.buscarClave=Entry(self.ventana)
        self.buscarClave.grid(row=7,column=1)
        #Boton buscar
        Button(self.ventana,text="Buscar alumno",command=self.buscarRegistro,bg="white",fg="black").grid(row=8,columnspan=2,sticky=W+E)
        #Tabla
        self.tabla=ttk.Treeview(self.ventana,columns=2)
        self.tabla.bind("<Double-Button-1>",self.doubleClickTabla)
        self.tabla.grid(row=9,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,where=""):
        registros=self.tabla.get_children()
        for registro in registros:
            self.tabla.delete(registro)
        if len(where)>0:
            cur=self.queryAlumnos("SELECT `nombre`,`clave` FROM `alumnos` "+where)
        else:
            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()
    def editarRegistro(self):
        if len(self.nombre.get())!=0 and len(self.clave.get())!=0:
            query="UPDATE alumnos set nombre='"+self.nombre.get()+"',clave='"+self.clave.get()+"' where clave='"+self.claveVieja+"'; "
            self.queryAlumnos(query)
            self.mensaje['text']="El alumno "+self.nombre.get()+" se a actualizado 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()
        self.crear["state"]="normal"
        self.editar["state"]="disabled"
        self.borrar["state"]="disabled"
    def doubleClickTabla(self,event):
        self.claveVieja=str(self.tabla.item(self.tabla.selection())["values"][0])
        self.nombre.delete(0,END)
        self.clave.delete(0,END)
        self.crear["state"]="disable"
        self.editar["state"]="normal"
        self.borrar["state"]="normal"
        self.nombre.insert(0,str(self.tabla.item(self.tabla.selection())["text"]))
        self.clave.insert(0,str(self.tabla.item(self.tabla.selection())["values"][0]))
    def borrarRegistro(self):
        if messagebox.askyesno(message="¿Realmente deseas borrar el registro?",title="Borrar alumno")==True:
            query="delete from alumnos where clave='"+self.claveVieja+"' "
            self.queryAlumnos(query)
            self.mensaje['text']="El alumno "+self.nombre.get()+" se a borrado exitosamente"
            self.nombre.delete(0,END)
            self.clave.delete(0,END)
            self.nombre.focus()
            self.mostrarDatos()
            self.crear["state"]="normal"
            self.editar["state"]="disabled"
            self.borrar["state"]="disabled"
    def buscarRegistro(self):
        where=" where 1=1 "
        if len(self.buscarNombre.get())>0 :
            where=where+" and nombre='"+self.buscarNombre.get()+"' "
        if len(self.buscarClave.get())>0 :
            where=where+" and clave='"+self.buscarClave.get()+"' "
        self.mostrarDatos(where)
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

Deja un comentario

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