笔者在用PyQt5写GUI时碰到了需要使用下拉式复选框的情况,但是PyQt5中没有相应的组件,而网上找到的方法大多是qt使用的,所以不能直接拿来用。
没办法,在这种让人无奈的情况下,笔者只能根据网上大神们的方法试着自己写一个喽。
你还别说,真就让我写出来了。(笔者是个菜鸟新手,所以这小小的成功让我很开心)
然后笔者就很严肃地将这个组件命名为QComboCheckBox,也就是QComboBox和QCheckBox的拼接。
废话不多说,直接先上效果图:
然后是代码:(第一个是基础,第二个是带全选和清空功能)
from PyQt5.QtWidgets import QComboBox,QLineEdit,QListWidget,QCheckBox,QListWidgetItem class ComboCheckBox(QComboBox): def __init__(self,items):#items==[str,str...] super(ComboCheckBox,self).__init__() self.items=items self.qCheckBox=[] self.qLineEdit=QLineEdit() self.qLineEdit.setReadOnly(True) qListWidget=QListWidget() self.row_num=len(self.items) for i in range(self.row_num): self.qCheckBox.append(QCheckBox()) qItem=QListWidgetItem(qListWidget) self.qCheckBox[i].setText(self.items[i]) qListWidget.setItemWidget(qItem,self.qCheckBox[i]) self.qCheckBox[i].stateChanged.connect(self.show) self.setLineEdit(self.qLineEdit) self.setModel(qListWidget.model()) self.setView(qListWidget) def Selectlist(self): Outputlist=[] for i in range(self.row_num): if self.qCheckBox[i].isChecked()==True: Outputlist.append(self.qCheckBox[i].text()) return Outputlist def show(self): show='' self.qLineEdit.setReadOnly(False) self.qLineEdit.clear() for i in self.Selectlist(): show+=i+';' self.qLineEdit.setText(show) self.qLineEdit.setReadOnly(True) from PyQt5.QtWidgets import QComboBox,QLineEdit,QListWidget,QCheckBox,QListWidgetItem class ComboCheckBox(QComboBox): def __init__(self,items):#items==[str,str...] super(ComboCheckBox,self).__init__() self.items=items self.items.insert(0,'全部') self.row_num=len(self.items) self.Selectedrow_num=0 self.qCheckBox=[] self.qLineEdit=QLineEdit() self.qLineEdit.setReadOnly(True) self.qListWidget=QListWidget() self.addQCheckBox(0) self.qCheckBox[0].stateChanged.connect(self.All) for i in range(1,self.row_num): self.addQCheckBox(i) self.qCheckBox[i].stateChanged.connect(self.show) self.setModel(self.qListWidget.model()) self.setView(self.qListWidget) self.setLineEdit(self.qLineEdit) def addQCheckBox(self,i): self.qCheckBox.append(QCheckBox()) qItem=QListWidgetItem(self.qListWidget) self.qCheckBox[i].setText(self.items[i]) self.qListWidget.setItemWidget(qItem,self.qCheckBox[i]) def Selectlist(self): Outputlist=[] for i in range(1,self.row_num): if self.qCheckBox[i].isChecked()==True: Outputlist.append(self.qCheckBox[i].text()) self.Selectedrow_num=len(Outputlist) return Outputlist def show(self): show='' Outputlist=self.Selectlist() self.qLineEdit.setReadOnly(False) self.qLineEdit.clear() for i in Outputlist: show+=i+';' if self.Selectedrow_num==0: self.qCheckBox[0].setCheckState(0) elif self.Selectedrow_num==self.row_num-1: self.qCheckBox[0].setCheckState(2) else: self.qCheckBox[0].setCheckState(1) self.qLineEdit.setText(show) self.qLineEdit.setReadOnly(True) def All(self,zhuangtai): if zhuangtai==2: for i in range(1,self.row_num): self.qCheckBox[i].setChecked(True) elif zhuangtai==1: if self.Selectedrow_num==0: self.qCheckBox[0].setCheckState(2) elif zhuangtai==0: self.clear() def clear(self): for i in range(self.row_num): self.qCheckBox[i].setChecked(False)
使用方法:
a=ComboCheckBox('子项列表')
Selectlist()获取被选子项列表
All()全选
clear()清空已选项
以上这篇PyQt5下拉式复选框QComboCheckBox的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
本文向大家介绍vue.js实现单选框、复选框和下拉框示例,包括了vue.js实现单选框、复选框和下拉框示例的使用技巧和注意事项,需要的朋友参考一下 Vue.js可以很方便的实现数据双向绑定,所以在处理表单,人机交互方面具有很大的优势。下边以单选框、复选框和下拉框为例介绍他们在HTML和Vue.js中的具体实现方式。 一、单选框 在传统的HTML中实现单选框的方法如下: 注:这里name属性值必
本文向大家介绍js+csss实现的一个带复选框的下拉框,包括了js+csss实现的一个带复选框的下拉框的使用技巧和注意事项,需要的朋友参考一下 效果图: css: html: js:
问题内容: 如何设置HTML复选框,单选按钮和下拉菜单的样式?可以吗 我想为复选框或单选按钮使用图像,对列表使用相同的图像-下拉箭头在大多数情况下看起来不太好。 问题答案: 请参阅jQuery插件的2个链接(用于样式化复选框和单选按钮): http://line25.com/articles/jquery-plugins-for-styling-checkbox-radio- buttons ht
问题内容: 我想设计一个复选框下拉列表,并使复选框为多选。我使用了下面的代码,但是由于每次单击复选框时模板都会刷新,因此无法进行多项选择,请提出一些建议吗? 问题答案: 您可以使用诸如 angularjs-dropdown-multiselect之类的 指令,您可以在互联网上很容易找到它 以下是一些示例: angularjs-下拉菜单,多选 - 小提琴 multiselectDropdown -
本文向大家介绍el-select 下拉框多选实现全选的实现,包括了el-select 下拉框多选实现全选的实现的使用技巧和注意事项,需要的朋友参考一下 在写一个功能时发现el-select支持多选,但是竟然不支持全选,好无语哦,那就自己实现一下吧~有两种方法,第二种感觉简单些 方法一:下拉项增加一个【全选】,然后应该有以下几种情况: 下拉选项全都勾选时,【全选】自动勾选; 下拉选项部分勾选时,点击
本文向大家介绍js和jquery分别验证单选框、复选框、下拉框,包括了js和jquery分别验证单选框、复选框、下拉框的使用技巧和注意事项,需要的朋友参考一下 本文分别介绍了js和jQuery验证单选框(radio)、多选框(checkbox)、下拉框(select),分享给大家供大家参考,具体内容如下 (1).首先说单选框(radio),radio和checkbox一样都是name相同值有多个在