我正在用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”时,列表不会用新数据更新。另一方面,我必须重新启动程序来查看数据库中的最新更新。我应该怎么做才能避免重新启动程序并立即进行更新?你知道吗
如果是其他函数,则需要在末尾调用
update()
。你知道吗这将在更新调用之前清除
self.list
小部件,否则会出现重复数据。调用self.update()
时,使用适当的参数,self.list
将用查询中的数据重新填充。你知道吗要记住的一点是,在将用户添加到数据库之后,一定要提交更改。否则,
update()
将看不到新用户的信息。你知道吗相关问题 更多 >
编程相关推荐