首页 > Python资料 博客日记
【python】PyQt5中富文本框QTextEdit的详细教程与应用实战
2024-09-06 13:00:06Python资料围观90次
✨✨ 欢迎大家来到景天科技苑✨✨
🎈🎈 养成好习惯,先赞后看哦~🎈🎈
🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,前后端开发,小程序开发,云原生K8S,人工智能,js逆向,App逆向,网络系统安全,数据分析,PyQt5和tkinter桌面开发,Django,fastapi,flask等框架,linux,shell脚本等实操经验,网站搭建,数据库等分享。所属的专栏:PyQt5桌面应用开发,零基础到进阶应用实战
景天的主页:景天科技苑
文章目录
QTextEdit
在PyQt5中,QTextEdit
是一个非常强大的多行文本编辑控件,它不仅能够显示和编辑纯文本,还支持富文本(包括HTML格式)的显示和编辑。这使得QTextEdit
成为在开发图形用户界面(GUI)应用时,用于处理文本内容的理想选择。本文将结合具体案例,详细介绍QTextEdit
的各种用法和功能。
一、创建QTextEdit对象
1.1 基本创建
要创建一个QTextEdit
对象,首先需要在PyQt5中导入相应的模块,并实例化QTextEdit
类。以下是一个基本的示例,展示了如何创建一个包含QTextEdit
的窗口:
from PyQt5.Qt import *
import sys
class Window(QWidget):
def __init__(self):
# 当我们继承某个类时,需要调用父类构造方法
super().__init__()
# 设置窗口标题
self.setWindowTitle("QTextEdit功能测试")
self.resize(500, 500)
self.setup_ui()
# 此处调用一个个UI的方法展示即可
def setup_ui(self):
#创建QTextEdit富文本输入框
te = QTextEdit("景天来了",self)
te.move(100,100)
te.resize(200,200)
#设置背景色
te.setStyleSheet("background-color:cyan;")
if __name__ == '__main__':
app = QApplication(sys.argv)
window = Window()
window.show()
sys.exit(app.exec_())
在这个示例中,我们首先导入了PyQt5的模块。然后,我们通过面向对象变成方式创建了一个QWidget
作为主窗口。通过实例化QTextEdit
,我们创建了一个文本编辑框,并将其移动,设置其大小和背景颜色,最后将这个布局设置给主窗口,并显示窗口。
1.2 设置和获取文本内容
QTextEdit
提供了多种方法来设置和获取文本内容。最常用的方法是setPlainText()
和toPlainText()
。
text_edit.setPlainText("Hello, PyQt5!")
text = text_edit.toPlainText()
通过setPlainText()
方法,我们可以将纯文本内容设置到QTextEdit
中。而toPlainText()
方法则用于获取QTextEdit
中的纯文本内容。
二、文本格式化和样式
2.1 字体和样式
QTextEdit
支持丰富的文本格式化功能,包括设置字体、颜色、样式和对齐方式等。你可以使用setFont()
方法来设置文本字体,或者使用QTextCursor
和QTextCharFormat
来更详细地设置选定文本的格式。
# 0. 导入需要的包和模块
from PyQt5.Qt import * # 主要包含了我们常用的一些类, 汇总到了一块
import sys
# 1. 创建一个应用程序对象
app = QApplication(sys.argv)
# 2. 控件的操作
# 2.1 创建控件
window = QWidget()
# 2.2 设置控件
#设置窗口标题,默认标题是python,只有顶级控件才可以设置标题栏的标题
window.setWindowTitle("字体样式")
#设置窗口大小,注意,设置的空间尺寸大小,不包含上面的标题栏
window.resize(500, 500)
text_edit = QTextEdit(window)
text_edit.move(100,100)
#设置普通文本
text_edit.setPlainText("Hello, PyQt5!")
# 设置字体
text_edit.setFont(QFont('Arial', 12))
# 2.3 展示控件
window.show()
# 3. 应用程序的执行, 进入到消息循环
sys.exit(app.exec_())
2.2 文本对齐
QTextEdit
支持段落对齐方式,包括左对齐、右对齐和居中对齐。要设置文本对齐方式,可以使用QTextBlockFormat
类,并结合QTextCursor
来实现。
# 0. 导入需要的包和模块
from PyQt5.Qt import * # 主要包含了我们常用的一些类, 汇总到了一块
import sys
# 1. 创建一个应用程序对象
app = QApplication(sys.argv)
# 2. 控件的操作
# 2.1 创建控件
window = QWidget()
# 2.2 设置控件
#设置窗口标题,默认标题是python,只有顶级控件才可以设置标题栏的标题
window.setWindowTitle("文本对齐")
#设置窗口大小,注意,设置的空间尺寸大小,不包含上面的标题栏
window.resize(500, 500)
text_edit = QTextEdit(window)
text_edit.move(100,100)
#设置普通文本
text_edit.setPlainText("Hello, PyQt5!")
cursor = QTextCursor(text_edit.document())
cursor.movePosition(QTextCursor.Start)
while not cursor.atEnd():
cursor.movePosition(QTextCursor.StartOfBlock)
cursor.select(QTextCursor.BlockUnderCursor)
block_format = QTextBlockFormat()
block_format.setAlignment(Qt.AlignCenter)
cursor.mergeBlockFormat(block_format)
cursor.movePosition(QTextCursor.EndOfBlock)
cursor.movePosition(QTextCursor.NextBlock)
# 2.3 展示控件
window.show()
# 3. 应用程序的执行, 进入到消息循环
sys.exit(app.exec_())
上述代码将QTextEdit
中的所有文本段落设置为居中对齐。
输入内容,也会居中对齐
2.3 设置只读状态
使用setReadOnly
方法可以设置QTextEdit
是否为只读状态。当设置为True
时,用户无法编辑文本,只能查看。
text_edit.setReadOnly(True) # 设置为只读
text_edit.setReadOnly(False) # 设置为可编辑
2.4 字体和格式设置
QTextEdit
支持丰富的文本格式化功能。可以通过setFont
和setFontPointSize
方法设置文本的字体和大小。如果需要更详细的格式化,如加粗、斜体、下划线等,可以使用QTextCursor
和QTextCharFormat
类。
以下是一个设置文本格式的示例:
from PyQt5.QtGui import QTextCursor, QTextCharFormat, QFont
cursor = text_edit.textCursor()
char_format = QTextCharFormat()
char_format.setFontWeight(QFont.Bold)
cursor.mergeCharFormat(char_format)
2.5 滚动条控制
QTextEdit
提供了verticalScrollBar
和horizontalScrollBar
方法来获取滚动条,从而实现对文本的滚动控制。如果需要自定义滚动行为,可以通过这些滚动条对象进行操作。
三、文本选择和操作
3.1 文本选择
用户可以通过鼠标或键盘选择QTextEdit
中的文本,并执行如复制、剪切和粘贴等操作。QTextEdit
也提供了一组方法来实现这些功能,例如selectAll()
、copy()
和paste()
。
# 选择所有文本
text_edit.selectAll()
# 复制选中的文本
text_edit.copy()
# 粘贴文本到光标位置
text_edit.paste()
3.2 撤销和重做
QTextEdit
支持撤销和重做功能,用户可以通过菜单项或快捷键来触发这些操作。你也可以通过编程方式来实现撤销和重做功能。
# 撤销操作
text_edit.undo()
# 重做操作
text_edit.redo()
四、自动换行和滚动
4.1 自动换行
QTextEdit
支持自动换行功能,当文本内容超出控件的显示范围时,会自动换行显示,而不是水平滚动。你可以通过setLineWrapMode()
方法来设置自动换行的模式。
# 设置自动换行模式为以控件宽度为限制,保持单词完整性
text_edit.setLineWrapMode(QTextEdit.WidgetWidth)
4.2 滚动控制
QTextEdit
提供了垂直和水平滚动条,你可以通过verticalScrollBar()
和horizontalScrollBar()
方法来获取这些滚动条,进而控制滚动条的位置。
vertical_scrollbar = text_edit.verticalScrollBar()
vertical_scrollbar.setValue(100) # 滚动到垂直位置100
五、高级用法
5.1 设置HTML内容
QTextEdit
支持HTML格式的文本。可以使用setHtml
方法来设置HTML内容,并使用toHtml
方法获取当前的HTML内容。这对于需要显示富文本的应用程序非常有用。
# 0. 导入需要的包和模块
from PyQt5.Qt import * # 主要包含了我们常用的一些类, 汇总到了一块
import sys
# 1. 创建一个应用程序对象
app = QApplication(sys.argv)
# 2. 控件的操作
# 2.1 创建控件
window = QWidget()
# 2.2 设置控件
#设置窗口标题,默认标题是python,只有顶级控件才可以设置标题栏的标题
window.setWindowTitle("设置html内容")
#设置窗口大小,注意,设置的空间尺寸大小,不包含上面的标题栏
window.resize(500, 500)
text_edit = QTextEdit(window)
text_edit.move(100,100)
text_edit.setHtml("<b>Hello</b> <i>PyQt5!</i>")
html_content = text_edit.toHtml()
print(html_content) # 输出HTML代码
# 2.3 展示控件
window.show()
# 3. 应用程序的执行, 进入到消息循环
sys.exit(app.exec_())
5.2 文本光标和文档操作
QTextCursor
是QTextEdit
中一个非常重要的类,它用于对文档进行编辑和格式化。通过textCursor
方法可以获得当前的光标对象,然后使用它来对选定的文本进行操作,如插入文本、删除文本、应用格式等。
5.2.1 插入图片
QTextEdit
支持在文本中插入图片。可以通过QTextDocument
的addResource
方法和QTextCursor
的insertImage
方法来实现。
# 0. 导入需要的包和模块
from PyQt5.Qt import * # 主要包含了我们常用的一些类, 汇总到了一块
import sys
# 1. 创建一个应用程序对象
app = QApplication(sys.argv)
# 2. 控件的操作
# 2.1 创建控件
window = QWidget()
# 2.2 设置控件
#设置窗口标题,默认标题是python,只有顶级控件才可以设置标题栏的标题
window.setWindowTitle("插入图片")
#设置窗口大小,注意,设置的空间尺寸大小,不包含上面的标题栏
window.resize(500, 500)
text_edit = QTextEdit(window)
text_edit.move(100,100)
image = QImage("../../imgs/python-gui.png")
cursor = text_edit.textCursor()
document = text_edit.document()
document.addResource(QTextDocument.ImageResource, QUrl("image"), image)
cursor.insertImage("image")
# 2.3 展示控件
window.show()
# 3. 应用程序的执行, 进入到消息循环
sys.exit(app.exec_())
六、实际应用案例
示例:富文本编辑器
以下是一个简单的富文本编辑器示例,它结合了QTextEdit
的多个功能,如设置文本格式、插入图片、显示HTML内容等。
from PyQt5.Qt import * # 主要包含了我们常用的一些类, 汇总到了一块
import sys
class RichTextEditor(QMainWindow):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.setWindowTitle('富文本编辑器')
self.setGeometry(100, 100, 800, 600)
self.text_edit = QTextEdit()
self.setCentralWidget(self.text_edit)
# 创建菜单栏
menubar = self.menuBar()
# 文件菜单
file_menu = menubar.addMenu('文件')
open_action = QAction('打开', self)
open_action.setShortcut('Ctrl+O')
open_action.triggered.connect(self.open_file)
file_menu.addAction(open_action)
# 插入菜单
insert_menu = menubar.addMenu('插入')
image_action = QAction('图片', self)
image_action.triggered.connect(self.insert_image)
insert_menu.addAction(image_action)
# 工具栏(这里仅作为示例,未实际创建)
# ...
def open_file(self):
# 实现打开文件的逻辑(略)
pass
def insert_image(self):
# 插入图片的逻辑
image_path = "../../imgs/python-gui.png" # 假设这是用户选择的图片路径
image = QImage(image_path)
cursor = self.text_edit.textCursor()
document = self.text_edit.document()
document.addResource(QTextDocument.ImageResource, QUrl("image"), image)
cursor.insertImage("image")
if __name__ == '__main__':
app = QApplication(sys.argv)
editor = RichTextEditor()
editor.show()
app.exec_()
点击插入
图片
在这个示例中,我们创建了一个QMainWindow
作为主窗口,并在其中放置了一个QTextEdit
作为文本编辑器。我们还添加了一个菜单栏,包括“文件”和“插入”两个菜单项,分别用于打开文件和插入图片。
注意:上述代码中的open_file
方法没有实现具体的文件打开逻辑,仅作为示例框架的一部分。在实际应用中,你需要使用QFileDialog
等类来实现文件选择功能。
八、总结
QTextEdit
是PyQt5中一个功能强大的文本编辑控件,支持纯文本和富文本的编辑和显示。通过本文的介绍和示例代码,你应该已经掌握了QTextEdit
的基本用法和高级功能。希望这些信息能够帮助你在开发基于PyQt5的应用程序时,更好地利用QTextEdit
控件。
标签:
相关文章
最新发布
- 【Python】selenium安装+Microsoft Edge驱动器下载配置流程
- Python 中自动打开网页并点击[自动化脚本],Selenium
- Anaconda基础使用
- 【Python】成功解决 TypeError: ‘<‘ not supported between instances of ‘str’ and ‘int’
- manim边学边做--三维的点和线
- CPython是最常用的Python解释器之一,也是Python官方实现。它是用C语言编写的,旨在提供一个高效且易于使用的Python解释器。
- Anaconda安装配置Jupyter(2024最新版)
- Python中读取Excel最快的几种方法!
- Python某城市美食商家爬虫数据可视化分析和推荐查询系统毕业设计论文开题报告
- 如何使用 Python 批量检测和转换 JSONL 文件编码为 UTF-8
点击排行
- 版本匹配指南:Numpy版本和Python版本的对应关系
- 版本匹配指南:PyTorch版本、torchvision 版本和Python版本的对应关系
- Python 可视化 web 神器:streamlit、Gradio、dash、nicegui;低代码 Python Web 框架:PyWebIO
- 相关性分析——Pearson相关系数+热力图(附data和Python完整代码)
- Python与PyTorch的版本对应
- Anaconda版本和Python版本对应关系(持续更新...)
- Python pyinstaller打包exe最完整教程
- Could not build wheels for llama-cpp-python, which is required to install pyproject.toml-based proj