修改其他类的列表框

时间:2014-07-21 14:25:12

标签: python mysql pyqt qlistwidget

我正在使用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”时,列表不会使用新数据进行更新。另一方面,我必须重新启动程序以观察数据库中的最新更新。我该怎么做才能避免重启程序并立即更新?

1 个答案:

答案 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()无法看到新用户的信息。