使用PyQt实现简易文本编辑器

 更新时间:2025年02月06日 09:44:32   作者:shanks66  
这篇文章主要为大家详细介绍了如何使用PyQt5框架构建一个简单的文本编辑器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

分析

实现了一个简单的文本编辑器,使用PyQt5框架构建。以下是代码的主要功能和特点:

主窗口类 (MyWindow)

继承自 QWidget 类。

使用 .ui 文件加载用户界面布局。

设置窗口标题、状态栏消息等。

创建菜单栏及其子菜单项(文件和编辑),并绑定相应的槽函数。

菜单操作

新建文件:清空文本编辑区域。

打开文件:通过文件对话框选择文件后读取其内容并显示在文本编辑区域。

保存文件:通过文件对话框选择保存位置并将文本编辑区域的内容写入文件。

退出程序:关闭窗口前询问是否保存当前文件。

语法高亮 (SyntaxHighlighter)

继承自 QSyntaxHighlighter 类。

定义关键字、注释和字符串的格式规则。

实现 highlightBlock 方法以根据定义的规则对每一行文本进行高亮处理。

运行程序

创建 QApplication 实例。

初始化 MyWindow 窗口实例并展示。

进入应用程序的事件循环。

主要组件

uic: 用于从 .ui 文件加载 Qt 用户界面。

QFileDialog: 提供打开和保存文件的对话框。

QMessageBox: 显示消息对话框以获取用户反馈。

QSyntaxHighlighter: 用于实现文本编辑区的语法高亮功能。

代码

from PyQt5 import uic
import sys
import re
from PyQt5.QtWidgets import QApplication, QWidget, QFileDialog, QMessageBox
from PyQt5.QtGui import QSyntaxHighlighter, QTextCharFormat, QColor, QFont
from PyQt5.QtCore import QRegularExpression

class MyWindow(QWidget):

    def __init__(self):
        super().__init__()
        self.init_ui()

    def init_ui(self):
        self.ui = uic.loadUi("./文本编辑器.ui")
        print(self.ui.__dict__)  
        self.ui.setWindowTitle("文本编辑器")  # 修改标题的名称

        self.textEdit = self.ui.textEdit
        self.syntaxHighlighter = SyntaxHighlighter(self.textEdit.document())

        self.statusBar = self.ui.statusBar
        self.statusBar().showMessage('状态栏')
        # 加载好ui文件之后再进行设置菜单栏
        menu = self.ui.menubar
        file_menu = menu.addMenu("文件")
        # 清空文本
        self.create_file = file_menu.addAction("新建")
        self.create_file.setShortcut('Ctrl+N')
        self.create_file.triggered.connect(self.newFile)

        # 打开文件动作
        self.open = file_menu.addAction("打开")
        self.open.setShortcut("Ctrl+O")
        self.open.triggered.connect(self.openFile)


        self.save = file_menu.addAction("保存")
        self.save.setShortcut("Ctrl+S")
        self.save.triggered.connect(self.saveFile)

        self.exit = file_menu.addAction("退出")
        self.exit.setShortcut("Ctrl+E")
        self.exit.triggered.connect(self.closeEvent)


        edit_menu = menu.addMenu("编辑")
        edit_menu.addAction("复制")
        edit_menu.addAction("粘贴")
        edit_menu.addAction("剪切")


    def newFile(self):
        # 清空文本编辑区域
        self.textEdit.clear()
        self.statusBar().showMessage('新文件')

    def openFile(self):
        # 打开文件对话框,读取文件内容,将其显示在textEdit中
        fileName, _ = QFileDialog.getOpenFileName(self, '打开文件', '', '文本文件 (*.txt);;所有文件 (*)')
        if fileName:
            with open(fileName, 'r', encoding='utf-8') as file:
                self.textEdit.setText(file.read())
        self.statusBar().showMessage('打开新文件')

    def saveFile(self):
        # 保存文件对话框,打开一个文件,将textEdit中的内容写进去
        fileName, _ = QFileDialog.getSaveFileName(self, '保存文件', '', '文本文件 (*.txt);;所有文件 (*)')
        if fileName:
            with open(fileName, 'w', encoding='utf-8') as file:
                file.write(self.textEdit.toPlainText())

    def closeEvent(self, event):
        # 关闭窗口时提示保存
        reply = QMessageBox.question(self, '退出', '你是否想保存文件?',
                                     QMessageBox.Yes | QMessageBox.No | QMessageBox.Cancel, QMessageBox.Cancel)

        if reply == QMessageBox.Yes:
            self.saveFile()
            event.accept()
        elif reply == QMessageBox.No:
            event.accept()
        else:
            event.ignore()


class SyntaxHighlighter(QSyntaxHighlighter):
    def __init__(self, parent=None):
        super().__init__(parent)

        keywordFormat = QTextCharFormat()
        keywordFormat.setForeground(QColor("blue"))
        keywordFormat.setFontWeight(QFont.Bold)

        commentFormat = QTextCharFormat()
        commentFormat.setForeground(QColor("green"))
        commentFormat.setFontItalic(True)

        stringFormat = QTextCharFormat()
        stringFormat.setForeground(QColor("red"))
        stringFormat.setFontWeight(QFont.Bold)

        keywords = ["def", "class", "import", "from", "if", "else", "elif", "for", "while", "return", "try", "except"]

        self.highlightingRules = []

        for word in keywords:
            escaped_word = re.escape(word)
            rule = QRegularExpression(rf"\b{escaped_word}\b")
            self.highlightingRules.append((rule, keywordFormat))

        rule = QRegularExpression(r"#[^\n]*")
        self.highlightingRules.append((rule, commentFormat))

        rule = QRegularExpression(r'"([^"\\]|\\.)*"')
        self.highlightingRules.append((rule, stringFormat))

    def highlightBlock(self, text):
        for pattern, format in self.highlightingRules:
            matchIterator = pattern.globalMatch(text)
            while matchIterator.hasNext():
                match = matchIterator.next()
                self.setFormat(match.capturedStart(), match.capturedLength(), format)


if __name__=="__main__":
    app = QApplication(sys.argv)

    w = MyWindow()
    # 展示窗口
    w.ui.show()

    app.exec()

图示

到此这篇关于使用PyQt实现简易文本编辑器的文章就介绍到这了,更多相关PyQt文本编辑器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用Python生成词云图的详细指南

    使用Python生成词云图的详细指南

    在数据可视化领域,词云图是一种非常直观且受欢迎的展示文本数据中关键词频率的方式,Python 中的wordcloud库提供了一种简单而强大的方法来生成词云图,本文就给大家介绍了使用Python生成词云图的详细指南,需要的朋友可以参考下
    2024-12-12
  • Python调用Elasticsearch更新数据库的操作方法

    Python调用Elasticsearch更新数据库的操作方法

    Elasticsearch是一个分布式、多租户的全文搜索引擎,支持HTTP Web接口和无模式的JSON文档,本文介绍Python调用Elasticsearch更新数据库的相关操作,感兴趣的朋友一起看看吧
    2024-12-12
  • Blueprint实现路由分组及Flask中session的使用详解

    Blueprint实现路由分组及Flask中session的使用详解

    这篇文章主要为大家介绍了Blueprint实现路由分组及Flask中session的使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • 一文带你了解Python中pymysql的使用

    一文带你了解Python中pymysql的使用

    pymysql就是联通mysql实现python窗口与mysql数据库交互的库,十分方便操作,这篇文章将详细说明如何掌握并使用该库,感兴趣的可以了解一下
    2023-02-02
  • Python中Windows和macOS文件路径格式不一致的解决方法

    Python中Windows和macOS文件路径格式不一致的解决方法

    在 Python 中,Windows 和 macOS 的文件路径字符串格式不一致主要体现在路径分隔符上,这种差异可能导致跨平台代码在处理文件路径时出错,下面我们看看如何解决吧
    2025-03-03
  • Python学习笔记(一)(基础入门之环境搭建)

    Python学习笔记(一)(基础入门之环境搭建)

    本系列为Python学习相关笔记整理所得,IT人,多学无害,多多探索,激发学习兴趣,开拓思维,不求高大上,只求懂点皮毛,作为知识储备,不至于落后太远。本文主要介绍Python的相关背景,环境搭建。
    2014-06-06
  • 如何使用Python实现一个简易的ORM模型

    如何使用Python实现一个简易的ORM模型

    ORM(Object Relational Mapping)是一种程序设计技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。本文将介绍如何使用Python实现一个简易的ORM
    2021-05-05
  • 使用celery和Django处理异步任务的流程分析

    使用celery和Django处理异步任务的流程分析

    Celery是 一个专注于实时处理的任务队列,它还支持任务调度。 Celery快速,简单,高度可用且灵活。这篇文章主要介绍了使用celery和Django处理异步任务的流程分析,需要的朋友可以参考下
    2020-02-02
  • 在Python中定义函数并调用的操作步骤

    在Python中定义函数并调用的操作步骤

    这篇文章主要介绍了在Python中如何定义函数并调用它,函数的定义和调用是Python编程中最基本也是最重要的概念之一,掌握它们对于进行有效的Python编程至关重要,需要的朋友可以参考下
    2024-01-01
  • Pytest Fixture参数讲解及使用

    Pytest Fixture参数讲解及使用

    这篇文章主要介绍了Pytest之Fixture参数详解及使用,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-01-01

最新评论