我正在使用pyqt为数据库制作GUI。数据库是用mysql编码的。此外,主窗口有一个QListWidget,它允许通过更新函数查看数据库的数据。
def update(self, bd1='',sql1=''):
try:
cur = bd1.cursor()
cur.execute(sql1)
data = cur.fetchall()
#print data
for registro in data:
#Asignacion de registros a variables
n = registro[0]
LName= registro[1]
Name = registro[2]
ID = registro[3]
LName1= registro[4]
Name1 = registro[5]
ID1 = registro[6]
Tip = registro[7]
Cel = registro[8]
Tel1 = registro[9]
Tel2 = registro[10]
Email= registro[11]
City = registro[12]
print 'Entro'
#Colocacion de datos al listbox
self.list.addItem(LName + "," + " " + Name)
self.list.addItem("CC" + " " + ID)
#Arreglo Cel
if (Cel==None or LName1==None) or (Tel1==None and Tel2==None) or Email==None:
pass
elif Tel1!=None and Tel2==None:
self.list.addItem("Tel: " + Tel1)
elif Tel1==None and Tel2!=None:
print "Error Telefonos en la base de datos"
else:
self.list.addItem("Cel: " + Cel)
self.list.addItem(LName1 + "," + " " + Name1)
self.list.addItem("CC" + " " + ID1)
self.list.addItem("Tel: " + Tel1 + " - " + Tel2)
self.list.addItem("Email: " + Email)
#Arreglo Ciudad
if City==None:
self.list.addItem("Ciudad: " + "Bucaramanga")
else:
self.list.addItem("Ciudad: " + City)
#Arreglo Tipologia
if Tip==None:
self.list.addItem(" ")
else:
self.list.addItem("Tipologia: " + Tip + "\n")
except:
print "Error en obtencion de datos"
#Desconexion de la BD
bd1.close()
此外,我创建了另一个允许添加新用户的类,但是当我调用函数“update”时,列表不会使用新数据进行更新。另一方面,我必须重新启动程序以观察数据库中的最新更新。我该怎么做才能避免重启程序并立即更新?
答案 0 :(得分:0)
如果你的其他功能,你需要在最后调用update()
。
def add_user():
# Code to add user to database
# remember to commit()
self.list.clear()
self.update(#appropriate parameters)
这会在您更新调用之前清除self.list
窗口小部件,否则您将出现重复数据。调用self.update()
时,如果使用适当的参数,self.list
将使用查询中的数据重新填充。
要记住的一件事是,在将用户添加到数据库之后,请务必提交更改。如果您没有,则update()
无法看到新用户的信息。