时间:2021-05-22
一、QCompleter类
自动补全会用到的一个类
主要代码
def init_lineedit(self): # 增加自动补全 self.completer = QCompleter(items_list) # 设置匹配模式 有三种: Qt.MatchStartsWith 开头匹配(默认) Qt.MatchContains 内容匹配 Qt.MatchEndsWith 结尾匹配 self.completer.setFilterMode(Qt.MatchContains) # 设置补全模式 有三种: QCompleter.PopupCompletion(默认) QCompleter.InlineCompletion QCompleter.UnfilteredPopupCompletion self.completer.setCompletionMode(QCompleter.PopupCompletion) # 给lineedit设置补全器 self.lineedit.setCompleter(self.completer) def init_combobox(self): # 增加选项元素 for i in range(len(items_list)): self.combobox.addItem(items_list[i]) self.combobox.setCurrentIndex(-1) # 增加自动补全 self.completer = QCompleter(items_list) self.completer.setFilterMode(Qt.MatchContains) self.completer.setCompletionMode(QCompleter.PopupCompletion) self.combobox.setCompleter(self.completer)完整代码:
import sysfrom PyQt5.QtWidgets import *from PyQt5.QtGui import *from PyQt5.QtCore import *################################################items_list=["C","C++","Java","Python","JavaScript","C#","Swift","go","Ruby","Lua","PHP"]################################################class Widget(QWidget): def __init__(self, *args, **kwargs): super(Widget, self).__init__(*args, **kwargs) layout = QHBoxLayout(self) self.lineedit = QLineEdit(self, minimumWidth=200) self.combobox = QComboBox(self, minimumWidth=200) self.combobox.setEditable(True) layout.addWidget(QLabel("QLineEdit", self)) layout.addWidget(self.lineedit) layout.addItem(QSpacerItem(20, 20, QSizePolicy.Expanding, QSizePolicy.Minimum)) layout.addWidget(QLabel("QComboBox", self)) layout.addWidget(self.combobox) #初始化combobox self.init_lineedit() self.init_combobox() #增加选中事件 self.combobox.activated.connect(self.on_combobox_Activate) def init_lineedit(self): # 增加自动补全 self.completer = QCompleter(items_list) # 设置匹配模式 有三种: Qt.MatchStartsWith 开头匹配(默认) Qt.MatchContains 内容匹配 Qt.MatchEndsWith 结尾匹配 self.completer.setFilterMode(Qt.MatchContains) # 设置补全模式 有三种: QCompleter.PopupCompletion(默认) QCompleter.InlineCompletion QCompleter.UnfilteredPopupCompletion self.completer.setCompletionMode(QCompleter.PopupCompletion) # 给lineedit设置补全器 self.lineedit.setCompleter(self.completer) def init_combobox(self): # 增加选项元素 for i in range(len(items_list)): self.combobox.addItem(items_list[i]) self.combobox.setCurrentIndex(-1) # 增加自动补全 self.completer = QCompleter(items_list) self.completer.setFilterMode(Qt.MatchContains) self.completer.setCompletionMode(QCompleter.PopupCompletion) self.combobox.setCompleter(self.completer) def on_combobox_Activate(self, index): print(self.combobox.count()) print(self.combobox.currentIndex()) print(self.combobox.currentText()) print(self.combobox.currentData()) print(self.combobox.itemData(self.combobox.currentIndex())) print(self.combobox.itemText(self.combobox.currentIndex())) print(self.combobox.itemText(index))if __name__ == "__main__": app = QApplication(sys.argv) w = Widget() w.show() sys.exit(app.exec_())二、QStandardItemModel类
最终效果
import sys# from PyQt5.Qt import QCompleterfrom PyQt5.Qt import QStandardItemModelfrom PyQt5.QtCore import Qtfrom PyQt5.QtCore import pyqtSlotfrom PyQt5.QtCore import pyqtSignalfrom PyQt5.QtWidgets import QFramefrom PyQt5.QtWidgets import QLabelfrom PyQt5.QtWidgets import QWidgetfrom PyQt5.QtWidgets import QLineEditfrom PyQt5.QtWidgets import QTextEditfrom PyQt5.QtWidgets import QCompleterfrom PyQt5.QtWidgets import QSizePolicyfrom PyQt5.QtWidgets import QMainWindowfrom PyQt5.QtWidgets import QPushButtonfrom PyQt5.QtWidgets import QGridLayoutfrom PyQt5.QtWidgets import QApplicationfrom View import interfaceclass MainWindow(QMainWindow): def __init__(self): super(MainWindow,self).__init__(None) self.setWindowTitle("对金属腐蚀性试验仪") self.initUI() def initUI(self): layout = QGridLayout() layout.setSpacing(10) self.loginLabel = QLabel("邮箱:") self.loginLabel.setAlignment(Qt.AlignRight) self.loginLabel.setStyleSheet("color:rgb(20,20,20,255);font-size:16px;font-weight:bold:text") self.loginTxt = QLineEdit() self.loginTxt.setText("admin") self.loginTxt.setPlaceholderText("User Name") self.loginTxt.setClearButtonEnabled(True) self.loginTxt.textChanged.connect(self.on_loginTxt_textChanged) #绑定槽函数 self.m_model = QStandardItemModel(0, 1, self) m_completer = QCompleter(self.m_model, self) self.loginTxt.setCompleter(m_completer) m_completer.activated[str].connect(self.onTxtChoosed) self.pwdLabel = QLabel("密码:") self.pwdLabel.setAlignment(Qt.AlignRight) self.pwdTxt = QLineEdit() self.pwdTxt.setContextMenuPolicy(Qt.NoContextMenu) #禁止复制粘贴 self.pwdTxt.setPlaceholderText("Password") self.pwdTxt.setText("admin") self.pwdTxt.setEchoMode(QLineEdit.Password) self.pwdTxt.setClearButtonEnabled(True) self.registeredBtn = QPushButton("注册") self.loginBtn = QPushButton("登陆") self.headLabel = QLabel("用户登陆") self.headLabel.resize(300,30) self.headLabel.setAlignment(Qt.AlignCenter) self.headLabel.setStyleSheet("color:rgb(10,10,10,255);font-size:25px;font-weight:bold;font-family:Roman times;") self.headLabel.setSizePolicy(QSizePolicy.Expanding,QSizePolicy.Expanding) layout.addWidget(self.headLabel,0,0,1,2) policy = self.headLabel.sizePolicy() print(policy.verticalPolicy()) policy.setVerticalPolicy(1) print(policy.verticalPolicy()) # policy.setVerticalPolicy(1) layout.addWidget(self.loginLabel,1,0) layout.addWidget(self.loginTxt,1,1) layout.addWidget(self.pwdLabel,2,0) layout.addWidget(self.pwdTxt,2,1) layout.addWidget(self.registeredBtn,3,0) layout.addWidget(self.loginBtn,3,1) frame = QFrame(self) frame.setLayout(layout) self.setCentralWidget(frame) self.resize(300,150) def onTxtChoosed(self, txt): self.loginTxt.setText(txt) @pyqtSlot(str) def on_loginTxt_textChanged(self, text): if '@' in self.loginTxt.text(): return emaillist = ["@163.com", "@qq.com", "@gmail.com", "@live.com", "@126.com", "@139.com"] self.m_model.removeRows(0, self.m_model.rowCount()) for i in range(0, len(emaillist)): self.m_model.insertRow(0) self.m_model.setData(self.m_model.index(0, 0), text + emaillist[i])if __name__ == '__main__': app = QApplication(sys.argv) mainWindow = MainWindow() mainWindow.show() mainWindow.activateWindow() mainWindow.raise_() app.exec_() del mainWindow del appQStandardItemModel类为存储自定义数据提供了一个通用模型。
QStandardItemModel可以用作标准Qt数据类型的存储库。它是模型/视图类之一,是Qt的模型/视图框架的一部分。
QStandardItemModel提供了一个经典的基于项目的方法来处理模型。 QStandardItemModel中的项目由QStandardItem提供。
QStandardItemModel实现了QAbstractItemModel接口,这意味着该模型可用于在支持该接口的任何视图(如QListView,QTableView和QTreeView以及您自己的自定义视图)中提供数据。为了提高性能和灵活性,您可能希望子类QAbstractItemModel为不同类型的数据存储库提供支持。例如,QDirModel为底层文件系统提供了一个模型接口。
当你想要一个列表或树时,你通常会创建一个空的QStandardItemModel并使用appendRow()向模型添加项目,使用item()来访问项目。如果您的模型表示一个表格,您通常会将表格的维度传递给QStandardItemModel构造函数,并使用setItem()将项目放入表格中。您还可以使用setRowCount()和setColumnCount()来更改模型的尺寸。要插入项目,请使用insertRow()或insertColumn(),并删除项目,请使用removeRow()或removeColumn()。
您可以使用setHorizontalHeaderLabels()和setVerticalHeaderLabels()来设置模型的标题标签。
您可以使用findItems()在模型中搜索项目,并通过调用sort()对模型进行排序。
调用clear()从模型中移除所有项目。
2.2 代码理解
self.loginTxt = QLineEdit() self.loginTxt.setText("admin") self.loginTxt.setPlaceholderText("User Name") self.loginTxt.setClearButtonEnabled(True)0 self.loginTxt.textChanged.connect(self.on_loginTxt_textChanged) #绑定槽函数1 self.m_model = QStandardItemModel(0, 1, self)2 m_completer = QCompleter(self.m_model, self)3 self.loginTxt.setCompleter(m_completer)4 m_completer.activated[str].connect(self.onTxtChoosed) def onTxtChoosed(self, txt): self.loginTxt.setText(txt) @pyqtSlot(str) def on_loginTxt_textChanged(self, text): if '@' in self.loginTxt.text(): return emaillist = ["@163.com", "@qq.com", "@gmail.com", "@live.com", "@126.com", "@139.com"] self.m_model.removeRows(0, self.m_model.rowCount()) for i in range(0, len(emaillist)): self.m_model.insertRow(0) self.m_model.setData(self.m_model.index(0, 0), text + emaillist[i])0-将文本改变信号连接到on_loginTxt_textChanged 函数处理
参考连接
到此这篇关于PyQt5 文本输入框自动补全QLineEdit的实现示例的文章就介绍到这了,更多相关PyQt5 文本输入框自动补全内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
PyQt5单行文本框控件QLineEdit介绍QLineEdit类是一个单行文本框控件,可以输入单行字符串。QLineEdit类中常用的方法如下表方法描述set
本文实例为大家分享了PyQt5单行文本框展示的具体代码,供大家参考,具体内容如下QLineEdit是一个允许输入和编辑纯文本的单行控件。系统中的撤销、重做、复制
本文实现了PyQt5个各种弹出窗口:输入框、消息框、文件对话框、颜色对话框、字体对话框、自定义对话框其中,为了实现自定义对话框的返回值,使用了信号/槽本文基于w
PyQt5输入对话框QInputDialog介绍QInputDialog控件是一个标准对话框,有一个文本框和两个按钮(ok和cancel)组成,当用户单击ok或
本文实例讲解了javascript输入框自动下拉补全操作,仿百度、谷歌搜索框提示,具体内容如下效果图:具体代码:NewDocument