一、自定義MyComboBox
# MyComboBox.py
from PyQt5.QtWidgets import QComboBox
from PyQt5.QtCore import pyqtSignal
class MyComboBox(QComboBox):
clicked = pyqtSignal() #創(chuàng)建一個信號
def showPopup(self): #重寫showPopup函數(shù)
self.clicked.emit() #發(fā)送信號
super(MyComboBox, self).showPopup() # 調(diào)用父類的showPopup()
二、使用MyComboBox創(chuàng)建窗口空間
# test_ui.py
self.PrintersList = MyComboBox(self.groupBox) # 修改后
# self.PrintersList = QtWidgets.QComboBox(self.groupBox) # 修改前
三、main函數(shù)中對clicked 信號進行綁定
# main_loop.py
self.PrintersList.clicked.connect(self.scan_printer_list_slot) # 信號與槽函數(shù)的綁定
# 槽函數(shù)的實現(xiàn)
def scan_printer_list_slot(self):
print("掃描打印機并刷新列表")
補充:PyQt5中QComboBox實現(xiàn)多選功能
網(wǎng)上大佬太多了,寫的啥沒看懂,自己摸索著也寫了個出來,也勉強能用。
功能:
QComboBox實現(xiàn)多選功能
返回選中的文本列表
一鍵全選和取消全選功能
from PyQt5 import QtCore, QtGui, QtWidgets
import sys
class CheckableComboBox(QtWidgets.QComboBox):
def __init__(self, parent=None):
super(CheckableComboBox, self).__init__(parent)
self.setModel(QtGui.QStandardItemModel(self))
self.view().pressed.connect(self.handleItemPressed)
self.checkedItems = []
self.view().pressed.connect(self.get_all)
self.view().pressed.connect(self.getCheckItem)
self.status = 0
def handleItemPressed(self, index): #這個函數(shù)是每次選擇項目時判斷狀態(tài)時自動調(diào)用的,不用管(自動調(diào)用)
item = self.model().itemFromIndex(index)
if item.checkState() == QtCore.Qt.Checked:
item.setCheckState(QtCore.Qt.Unchecked)
else:
item.setCheckState(QtCore.Qt.Checked)
def getCheckItem(self):
# getCheckItem方法可以獲得選擇的項目列表,自動調(diào)用。
for index in range(1,self.count()):
item = self.model().item(index)
if item.checkState() == QtCore.Qt.Checked:
if item.text() not in self.checkedItems:
self.checkedItems.append(item.text())
else:
if item.text() in self.checkedItems:
self.checkedItems.remove(item.text())
print("self.checkedItems為:",self.checkedItems)
return self.checkedItems #實例化的時候直接調(diào)用這個self.checkedItems就能獲取到選中的值,不需要調(diào)用這個方法,方法會在選擇選項的時候自動被調(diào)用。
def get_all(self): #實現(xiàn)全選功能的函數(shù)(自動調(diào)用)
all_item = self.model().item(0)
for index in range(1,self.count()): #判斷是否是全選的狀態(tài),如果不是,全選按鈕應(yīng)該處于未選中的狀態(tài)
if self.status ==1:
if self.model().item(index).checkState() == QtCore.Qt.Unchecked:
all_item.setCheckState(QtCore.Qt.Unchecked)
self.status = 0
break
if all_item.checkState() == QtCore.Qt.Checked:
if self.status == 0 :
for index in range(self.count()):
self.model().item(index).setCheckState(QtCore.Qt.Checked)
self.status = 1
elif all_item.checkState() == QtCore.Qt.Unchecked:
for index in range(self.count()):
if self.status == 1 :
self.model().item(index).setCheckState(QtCore.Qt.Unchecked)
self.status = 0
if __name__ == "__main__":
app = QtWidgets.QApplication(sys.argv)
dialog = QtWidgets.QMainWindow()
mainWidget = QtWidgets.QWidget()
dialog.setCentralWidget(mainWidget)
ComboBox = CheckableComboBox(mainWidget)
ComboBox.addItem("全選")
for i in range(6):
ComboBox.addItem("Combobox Item " + str(i))
dialog.show()
sys.exit(app.exec_())
總結(jié)(用法):
直接實例化一個Qcombox
使用ComboBox.addItem方法添加項目
調(diào)用ComboBox.checkedItems的屬性就能獲取到選中的文本列表
內(nèi)置函數(shù)基本都是自動的,統(tǒng)統(tǒng)不用管
調(diào)用checkedItems屬性的時候最后寫在ComboBox的槽函數(shù)里,這樣才能獲取到更改后的屬性,不然可能得到的會是空值。
補充:
定義一個槽函數(shù)self.get_checkedItems_slot用于獲取更改后的checkedItems屬性,下面三種ComboBox的信號槽選一種來用就行,推薦第一種。
ComboBox.activated.connect(self.get_checkedItems_slot) #推薦
ComboBox.highlighted.connect(self.get_checkedItems_slot)
ComboBox.currentIndexChanged.connect(self.get_checkedItems_slot)
挺不容易的,網(wǎng)上資料有關(guān)Pyqt太少了,要么是Qt的,要么寫得太復(fù)雜,要么沒講解的,大多是靠自己摸索出來的。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- PyQt5 QListView 高亮顯示某一條目的案例
- pyqt5 QListWidget的用法解析
- Pyqt5 實現(xiàn)多線程文件搜索的案例
- PyQt5按下按鍵選擇文件夾并顯示的實現(xiàn)
- 關(guān)于PyQt5主窗口圖標顯示問題匯總
- PyQt5設(shè)置登錄界面及界面美化的實現(xiàn)