[Python自学] PyQT5-QLabel、QLineEdit、QTextEdit控件

一、控件添加提示信息

将鼠标停在控件上,可以显示一个提示的信息。

需要引入: from PyQt5.QtWidgets import QToolTip 

如果需要修改字体,则需要引入: from PyQt5.QtGui import QFont 

class MyWindow(QMainWindow):
    def __init__(self):
        super(MyWindow, self).__init__()
        self.initUI()

    def initUI(self):
        QToolTip.setFont(QFont("SansSerif",12))  # 设置提示信息的字体
        self.setToolTip("<b>你好啊</b>")  # 设置提示信息,当鼠标悬停的时候会显示提示信息

效果:

除了给窗口可以添加提示信息,给其他控件也是可以添加的,方法一致。

二、QLabel控件

1.QLabel使用示例

import sys

from PyQt5.QtWidgets import QVBoxLayout, QApplication, QLabel, QWidget
# 使用调色板
from PyQt5.QtGui import QPalette, QPixmap, QIcon
# 导入QT,其中包含一些常量,例如颜色等
from PyQt5.QtCore import Qt


class QLabelDemo(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        label1 = QLabel(self)
        label2 = QLabel(self)
        label3 = QLabel(self)
        label4 = QLabel(self)

        # 设置Label1的属性
        label1.setText("<font color=yellow>这是一个文本标签.</font>")  # 设置label1的文本内容
        label1.setAutoFillBackground(True)  # 允许自动填充背景
        palette = QPalette()  # 定义一个调色板实例
        palette.setColor(QPalette.Window, Qt.blue)  # 配置调色板
        label1.setPalette(palette)  # 使用配置好的调色板
        label1.setAlignment(Qt.AlignCenter)  # 设置文本居中

        # 设置Label2的属性
        label2.setText("<a href='#'>欢迎使用Python GUI程序</a>")

        # 设置label3的属性
        label3.setAlignment(Qt.AlignCenter)  # 文本居中
        label3.setToolTip("这是一个图片标签")  # 添加提示标签
        label3.setPixmap(QPixmap("./images/ailusha.png"))  # 内容使用一张图片来填充

        # 设置label4的属性
        label4.setText("<a href='https://www.jd.com/'>点击进入京东</a>")  # 设置一个超链接
        label4.setAlignment(Qt.AlignRight)  # 文本靠右
        label4.setToolTip("点击进入京东商城")  # 设置提示标签

        # 使用垂直布局对所有label进行布局
        vbox = QVBoxLayout()  # 定义一个垂直布局实例
        vbox.addWidget(label1)  # 将label加到这个布局中
        vbox.addWidget(label2)
        vbox.addWidget(label3)
        vbox.addWidget(label4)

        # 绑定信号和槽函数
        label2.linkHovered.connect(self.linkHoverd)  # 将label2的鼠标悬停信号和槽函数绑定
        label4.linkActivated.connect(self.linkActivated)  # 将label4的点击事件和槽函数绑定

        # 将垂直布局用到主窗口
        self.setLayout(vbox)
        # 添加窗口标题
        self.setWindowTitle("QLabel控件Demo")

    # 鼠标悬停在标签时槽函数
    def linkHoverd(self):
        print("鼠标悬停在label上")

    def linkActivated(self):
        print("label被点击")


if __name__ == '__main__':
    app = QApplication(sys.argv)
    app.setWindowIcon(QIcon("images/icon.ico"))
    # 创建一个主窗口
    mainWin = QLabelDemo()
    # 显示
    mainWin.show()
    # 主循环
    sys.exit(app.exec_())

在以上代码中,我们创建了四个QLabel实例,每个实例作用不同。具体参考代码注释。

实现效果:

2.QLabel添加伙伴关系

def initUI(self):
    nameLabel = QLabel("&Name", self)  # 注意这里的&N,表示热键为Alt+N
    nameLineEdit = QLineEdit(self)  # 用户名输入框
    nameLabel.setBuddy(nameLineEdit)  # 将输入框绑定为nameLabel的伙伴,使用热键时,光标切换到该输入框

    pwdLabel = QLabel("&Password", self)  # 注意这里的&P,表示热键为Alt+P
    pwdLineEdit = QLineEdit(self)
    pwdLabel.setBuddy(pwdLineEdit)

    gbox = QGridLayout()  # 使用栅格布局
    gbox.addWidget(nameLabel, 0, 0)
    gbox.addWidget(nameLineEdit, 0, 1, 1, 2)  # 占用1行2列
    gbox.addWidget(pwdLabel, 1, 0)
    gbox.addWidget(pwdLineEdit, 1, 1, 1, 2)  # 占用1行2列

    # 将栅格布局用到主窗口
    self.setLayout(gbox)
    # 添加窗口标题
    self.setWindowTitle("QLabel控件Demo")

在第1节的代码中,将initUI替换为以上函数。

实现效果:

当我们按Alt+N时,光标切换到用户名输入框,当按Alt+P时,光标切换到密码输入框。

 二、QLineEdit控件

 QLineEdit标签是一个单行文本输入控件

1.回显模式

 QLineEdit标签有4种回显模式(EchoMode)。

四种回显模式:

1)Normal,即我们平时使用输入框的模式

2)NoEcho,即不显示,有点像我们在Linux命令行中输入密码时,什么都不显示,但数据已经提交上去了。

3)Password,即输入的内容回显为星星或黑点形式,一般用于密码输入框。

4)PasswordEchoOnEdit,输入时会显示明文,切换到其他控件时显示星星或黑点。

如何设置EchoMode:

nameLineEdit.setEchoMode(QLineEdit.Normal)  # 设置为普通回显模式
pwdLineEdit.setEchoMode(QLineEdit.Password)  # 设置为密码回显模式

效果:

2.placeholder文本

输入框为空时,显示灰色的提示文本:

nameLineEdit.setPlaceholderText("请输入用户名")

效果:

2.校验器

校验器可以对输入框输入的内容进行校验,只允许我们输入规定好字符种类。

def initUI(self):
    # 整数输入框
    intLineEdit = QLineEdit(self)  # 用户名输入框
    # 只能输入字母和数字的输入框
    regLineEdit = QLineEdit(self)
    # 整数校验器
    intValidator = QIntValidator(self)
    intValidator.setRange(1, 99)
    # 正则表达式校验器
    regValidator = QRegExpValidator(self)
    reg = QRegExp("[a-zA-Z0-9]+$")
    regValidator.setRegExp(reg)

    # 使用校验器
    intLineEdit.setValidator(intValidator)
    regLineEdit.setValidator(regValidator)

    vbox = QVBoxLayout()
    vbox.addWidget(intLineEdit)
    vbox.addWidget(regLineEdit)

    # 将垂直布局用到主窗口
    self.setLayout(vbox)
    # 添加窗口标题
    self.setWindowTitle("QLineEdit控件Demo")

效果:

 

第一个输入框除了1-99的数字,其他都不能输入。第二个输入框除了字母和数字,其他都不能输入。

注:除了整数校验器,还有浮点型等很多校验器。

3.使用掩码来限时输入格式

除了第2节中的校验器可以限制输入,QT还给我们提供了掩码来限制输入。

例如:

def initUI(self):
    
    # 定义几个QLineEdit实例
    ipLineEdit = QLineEdit(self)
    macLineEdit = QLineEdit(self)
    dateLineEdit = QLineEdit(self)
    licenseLineEdit = QLineEdit(self)

    # 使用掩码
    ipLineEdit.setInputMask('000.000.000.000;_')  # 0表示只能输入数字,也可以不输入
    macLineEdit.setInputMask('HH:HH:HH:HH:HH:HH;_')  # H表示十六进制字符[a-fA-f0-9]
    dateLineEdit.setInputMask('0000-00-00')
    licenseLineEdit.setInputMask('>AAAA-AAAA-AAAA-AAAA-AAAA;#')  # A表示A-Za-z,>表示后面全部为大写

    vbox = QVBoxLayout()
    vbox.addWidget(ipLineEdit)
    vbox.addWidget(macLineEdit)
    vbox.addWidget(dateLineEdit)
    vbox.addWidget(licenseLineEdit)

    # 将垂直布局用到主窗口
    self.setLayout(vbox)
    # 添加窗口标题
    self.setWindowTitle("QLineEdit控件Demo")

效果:

 

 

QT为我们提供了以下掩码:

A

ASCII字母字符是必须的,取值空间是A-Z,a-z

a

ASCII 字母字符是允许的但不是必须的.

N

ASCII字母字符是必须的. A-Z, a-z, 0-9.

n

ASCII 字母字符是允许的但不是必须的.

X

任何字符都可以,是必须需要的.

x

任何字符都允许的,但不是必须需要的.

9

ASCII 数字是必须要的. 0-9.

0

ASCII 数字是允许的,但不是必须要的.

D

ASCII  数字是必须要的. 1-9.

d

ASCII 数字是允许的,但不是必须要的 (1-9).

#

ASCII 数字是或加减符号允许的,但不是必须要的.

H

十六进制数据字符是必须要的. A-F, a-f, 0-9.

h

十六进制数据字符是允许的,但不是必须要的.

B

二进制数据字符是必须要的. 0-1.

b

二进制数据字符是允许的,但不是必须要的.

>

所有的字符字母都都大写的.

<

所有的字符字幕都是小写的.

!

关闭大小写.

\

使用 \ 去转义上面的字符,如果再需要显示上述字符的时候.

 

三、QTextEdit控件

1.使用QTextEdit控件

前面学习的QLineEdit是单行输入框,而QTextEdit是多行输入框。

def initUI3(self):
    self.textEdit = QTextEdit()
    self.buttontext = QPushButton("显示文本")
    self.buttonhtml = QPushButton("显示HTML")

    vbox = QVBoxLayout()
    vbox.addWidget(self.textEdit)
    vbox.addWidget(self.buttontext)
    vbox.addWidget(self.buttonhtml)

    self.setLayout(vbox)
    self.buttontext.clicked.connect(self.onClickButtonText)
    self.buttonhtml.clicked.connect(self.onClickButtonHtml)
    
# 点击buttontext按钮触发该槽函数
def onClickButtonText(self):
    self.textEdit.setPlainText("Hello World,世界你好吗?")
    
# 点击buttonhtml按钮触发该槽函数
def onClickButtonHtml(self):
    self.textEdit.setHtml("<font color='blue' size='5'>Hello World</font>")

效果:

2.获取QTextEdit中的值

self.textEdit.toPlainText()  # 获取其中纯文本
self.textEdit.toHtml()  # 获取其中的html标签

 

===

posted @ 2020-06-12 17:20  风间悠香  阅读(2348)  评论(0编辑  收藏  举报