Bootstrap

python QtableWidget问题小结

python QtableWidget问题小结

  最近用到了Python的pyqt5 QTableWidget显示数据库,这里把过程中遇到的与Qtablewidget相关的问题做一个简单总结。

1. 数据库里数据类型为int的一列不能在QtableWidget里正常显示

因为Qtable自身只支持字符串。解决其它格式数据的希纳是方法有2种,一种是把要显示的数据在python里用str()转为字符串,另一种方法是在QTableWidget的每个表格里插入lineedit等控件,lineedit显示字符串就不受限制了。

2. 对QtableWidget里的数据进行筛选显示的实现

这里借鉴了Qt qtablewidget 实现筛选这篇博文实现思路,在此期间一直没有搜到python实例,我把自己用python实现的代码主要部分截取分享出来。
筛选的条件是另一个独立控件lineedit里的内容。
代码片.

// screen item
 tablewidget.setRowHidden(i,True)
 s_c =self.lineEdit.Text()
 tab_count=self.tablewidget.rowCount()
 if s_c ='':
    for i in range(tab_count):
        self.tablewidget.setRowHidden(i,False)
 else: 
       item_screen=self.tablewidget.finditems(s_c, QtCore.Qt.MatchContains)
       for i in range(tab_count):
           self.tablewidget.setRowHidden(i,True)
       if len(item_screen):
           for i in range(len(item_screen)):
               self.tablewidget.setRowHidden(item_screen[i].row().False)

3. 槽函数的暂停

这里对应的是一个应用场景:一个tablewidget显示不同的数据表,也就是多个数据表的显示切换。
在显示其中一个主要的数据表时,tabelwidget要有双击一行弹出窗口功能,另外的表格显示时则不需要或者说暂停这个功能,这里就用到了blocksignals(True)
初始考虑使用解除信号和槽函数关联的方法,但是实现的效果与想要的效果不一致。利用blocksignals(True)完美解决。

;