from tkinter import *
import tkinter.ttk as ttk
import tkinter.messagebox as tkMessageBox
import sqlite3
def Database():
global conn, cursor
conn = sqlite3.connect("inventarioplantas.db")
cursor = conn.cursor()
cursor.execute(
"CREATE TABLE IF NOT EXISTS REGISTRATION (RID INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, NOME TEXT, "
"QUANTIDADE TEXT, DATAPLANTACAO TEXT, DATARETIRADA TEXT, FORNECEDOR TEXT,CONTACTO TEXT )")
def DisplayForm():
root = Tk()
root.geometry("900x500")
root.title("Inventário das Plantas")
global tree
global SEARCH
global nome_planta,quantidade,data_plantacao,data_retirada,Fornecedora,contacto
SEARCH = StringVar()
nome_planta = StringVar()
quantidade = StringVar()
data_plantacao = StringVar()
data_retirada = StringVar()
Fornecedora = StringVar()
contacto = StringVar()
TopViewForm = Frame(root, width=600, bd=1, relief=SOLID)
TopViewForm.pack(side=TOP, fill=X)
LFrom = Frame(root, width="350",bg="#15244C")
LFrom.pack(side=LEFT, fill=Y)
LeftViewForm = Frame(root, width=500,bg="#0B4670")
LeftViewForm.pack(side=LEFT, fill=Y)
MidViewForm = Frame(root, width=600)
MidViewForm.pack(side=RIGHT)
lbl_text = Label(TopViewForm, text="Inventário de Plantas", font=('verdana', 18), width=600,bg="cyan")
lbl_text.pack(fill=X)
Label(LFrom, text="Nome da Planta ", font=("Arial", 12),bg="#15244C",fg="white").pack(side=TOP)
Entry(LFrom,font=("Arial",10,"bold"),textvariable=nome_planta).pack(side=TOP, padx=10, fill=X)
Label(LFrom, text="Quantidade ", font=("Arial", 12), bg="#15244C", fg="white").pack(side=TOP)
Entry(LFrom, font=("Arial", 10, "bold"), textvariable=quantidade).pack(side=TOP, padx=10, fill=X)
Label(LFrom, text="Data de Plantação ", font=("Arial", 12),bg="#15244C",fg="white").pack(side=TOP)
Entry(LFrom, font=("Arial", 10, "bold"),textvariable=data_plantacao).pack(side=TOP, padx=10, fill=X)
Label(LFrom, text="Data de Arranque ", font=("Arial", 12), bg="#15244C", fg="white").pack(side=TOP)
Entry(LFrom, font=("Arial", 10, "bold"), textvariable=data_retirada).pack(side=TOP, padx=10, fill=X)
Label(LFrom, text="Fornecedor ", font=("Arial", 12), bg="#15244C", fg="white").pack(side=TOP)
Entry(LFrom, font=("Arial", 10, "bold"), textvariable=Fornecedora).pack(side=TOP, padx=10, fill=X)
Label(LFrom, text="Contacto ", font=("Arial", 12),bg="#15244C",fg="white").pack(side=TOP)
Entry(LFrom, font=("Arial", 10, "bold"),textvariable=contacto).pack(side=TOP, padx=10, fill=X)
#
Button(LFrom,text="Submeter",font=("Arial", 10, "bold"),bg="#15244C",fg="white",command=register
).pack(side=TOP, padx=10,pady=5, fill=X)
lbl_txtsearch = Label(LeftViewForm, text="Digite o Nome da Planta", font=('verdana', 10),bg="#0B4670")
lbl_txtsearch.pack()
search = Entry(LeftViewForm, textvariable=SEARCH, font=('verdana', 15), width=10)
search.pack(side=TOP, padx=10, fill=X)
#
btn_search = Button(LeftViewForm, text="Pesquisa",bg="cyan", command=SearchRecord)
btn_search.pack(side=TOP, padx=10, pady=10, fill=X)
#
btn_view = Button(LeftViewForm, text="Ver tudo",bg="cyan",command=DisplayData)
btn_view.pack(side=TOP, padx=10, pady=10, fill=X)
#
btn_Limpar = Button(LeftViewForm, text="Limpar",bg="cyan",command=limpar)
btn_Limpar.pack(side=TOP, padx=10, pady=10, fill=X)
#"
btn_apagar = Button(LeftViewForm, text="Apagar",bg="cyan",command=apagar)
btn_apagar.pack(side=TOP, padx=10, pady=10, fill=X)
#
btn_actualizar = Button(LeftViewForm, text="Actualizar",bg="cyan",command=actualizacao)
btn_actualizar.pack(side=TOP, padx=10, pady=10, fill=X)
scrollbarx = Scrollbar(MidViewForm, orient=HORIZONTAL)
scrollbary = Scrollbar(MidViewForm, orient=VERTICAL)
tree = ttk.Treeview(MidViewForm,columns=("Student Id", "Nome", "Quantidade", "Dataplantacao","Dataretirada",
"Empresa_fornecedora",'Contacto'),
selectmode="extended", height=100, yscrollcommand=scrollbary.set, xscrollcommand=scrollbarx.set)
scrollbary.config(command=tree.yview)
scrollbary.pack(side=RIGHT, fill=Y)
scrollbarx.config(command=tree.xview)
scrollbarx.pack(side=BOTTOM, fill=X)
tree.heading('Student Id', text="Id", anchor=W)
tree.heading('Nome', text="Nome da Empresa", anchor=W)
tree.heading('Quantidade', text="Quantidade", anchor=W)
tree.heading('Dataplantacao', text="Data de Plantação", anchor=W)
tree.heading('Dataretirada', text="Data de Retirada", anchor=W)
tree.heading('Empresa_fornecedora', text="Nome da Fornecedora", anchor=W)
tree.heading('Contacto', text="Contacto", anchor=W)
tree.column('#0', stretch=NO, minwidth=0, width=0)
tree.column('#1', stretch=NO, minwidth=0, width=100)
tree.column('#2', stretch=NO, minwidth=0, width=120)
tree.column('#3', stretch=NO, minwidth=0, width=120)
tree.column('#4', stretch=NO, minwidth=0, width=120)
tree.column('#5', stretch=NO, minwidth=0, width=120)
tree.column('#6', stretch=NO, minwidth=0, width=120)
tree.pack()
def SearchRecord():
Database()
if SEARCH.get() != "":
tree.delete(*tree.get_children())
cursor=conn.execute("SELECT * FROM REGISTRATION WHERE NOME LIKE ?", ('%' + str(SEARCH.get()) + '%',))
fetch = cursor.fetchall()
for data in fetch:
tree.insert('', 'end', values=(data))
cursor.close()
conn.close()
def apagar():
Database()
if not tree.selection():
tkMessageBox.showwarning("Atenção","Selecione a Planta a eliminar ")
else:
result = tkMessageBox.askquestion('Confirmar', 'Deseja apagar o registo da planta?',
icon="warning")
if result == 'yes':
curItem = tree.focus()
contents = (tree.item(curItem))
selecteditem = contents['values']
tree.delete(curItem)
cursor=conn.execute("DELETE FROM REGISTRATION WHERE RID = %d" % selecteditem[0])
conn.commit()
cursor.close()
conn.close()
conn.close()
def actualizacao():
Database()
vnome_planta=nome_planta.get()
vquantidade=quantidade.get()
vdata_plantacao=data_plantacao.get()
vdata_retirada=data_retirada.get()
vFornecedora=Fornecedora.get()
vcontacto=contacto.get()
if vnome_planta=='' or vquantidade==''or vdata_plantacao=='' or vdata_retirada==''or vFornecedora=='' or vcontacto=='':
tkMessageBox.showinfo("Atenção","Preencha todos os espaços!!!")
else:
curItem = tree.focus()
contents = (tree.item(curItem))
selecteditem = contents['values']
conn.execute('UPDATE REGISTRATION SET NOME=?,QUANTIDADE=?,DATAPLANTACAO=?,DATARETIRADA=?,FORNECEDOR=?,CONTACTO=? WHERE RID = ?',
(vnome_planta,vquantidade,vdata_plantacao,vdata_retirada,vFornecedora,vcontacto,selecteditem[0]))
conn.commit()
tkMessageBox.showinfo("Mensagem","Actualizado com Sucesso!")
limpar()
DisplayData()
conn.close()
def DisplayData():
Database()
tree.delete(*tree.get_children())
cursor=conn.execute("SELECT * FROM REGISTRATION")
fetch = cursor.fetchall()
for data in fetch:
tree.insert('', 'end', values=(data))
tree.bind("<Double-1>",OnDoubleClick)
cursor.close()
conn.close()
def OnDoubleClick(self):
curItem = tree.focus()
contents = (tree.item(curItem))
selecteditem = contents['values']
nome_planta.set(selecteditem[1])
quantidade.set(selecteditem[2])
data_plantacao.set(selecteditem[3])
data_retirada.set(selecteditem[4])
Fornecedora.set(selecteditem[5])
contacto.set(selecteditem[6])
def register():
Database()
vnome_planta=nome_planta.get()
vquantidade=quantidade.get()
vdata_plantacao=data_plantacao.get()
vdata_retirada=data_retirada.get()
vFornecedora=Fornecedora.get()
vcontacto=contacto.get()
if vnome_planta=='' or vquantidade==''or vdata_plantacao=='' or vdata_retirada==''or vFornecedora=='' or vcontacto=='':
tkMessageBox.showinfo("Atenção","Preencha os espaços vazios!!!")
else:
conn.execute('INSERT INTO REGISTRATION (NOME,QUANTIDADE,DATAPLANTACAO,DATARETIRADA,FORNECEDOR,CONTACTO) \
VALUES (?,?,?,?,?,?)',(vnome_planta,vquantidade,vdata_plantacao,vdata_retirada,vFornecedora,vcontacto));
conn.commit()
tkMessageBox.showinfo("Sucesso","Planta adicionada com Sucesso")
DisplayData()
conn.close()
def limpar():
tree.delete(*tree.get_children())
DisplayData()
SEARCH.set("")
nome_planta.get()
nome_planta.set("")
quantidade.set("")
data_plantacao.set("")
data_retirada.set("")
Fornecedora.set("")
contacto.set("")
DisplayForm()
if __name__=='__main__':
mainloop()
Comentários
Enviar um comentário