从其他类修改列表框

2024-03-28 10:44:30 发布

您现在位置:Python中文网/ 问答频道 /正文

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


Tags: selfnone数据库dataemaildelistprint
1条回答
网友
1楼 · 发布于 2024-03-28 10:44:30

如果是其他函数,则需要在末尾调用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()将看不到新用户的信息。你知道吗

相关问题 更多 >