亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用PyQt實現(xiàn)簡易文本編輯器

 更新時間:2025年02月06日 09:44:32   作者:shanks66  
這篇文章主要為大家詳細介紹了如何使用PyQt5框架構建一個簡單的文本編輯器,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下

分析

實現(xiàn)了一個簡單的文本編輯器,使用PyQt5框架構建。以下是代碼的主要功能和特點:

主窗口類 (MyWindow)

繼承自 QWidget 類。

使用 .ui 文件加載用戶界面布局。

設置窗口標題、狀態(tài)欄消息等。

創(chuàng)建菜單欄及其子菜單項(文件和編輯),并綁定相應的槽函數(shù)。

菜單操作

新建文件:清空文本編輯區(qū)域。

打開文件:通過文件對話框選擇文件后讀取其內容并顯示在文本編輯區(qū)域。

保存文件:通過文件對話框選擇保存位置并將文本編輯區(qū)域的內容寫入文件。

退出程序:關閉窗口前詢問是否保存當前文件。

語法高亮 (SyntaxHighlighter)

繼承自 QSyntaxHighlighter 類。

定義關鍵字、注釋和字符串的格式規(guī)則。

實現(xiàn) highlightBlock 方法以根據(jù)定義的規(guī)則對每一行文本進行高亮處理。

運行程序

創(chuàng)建 QApplication 實例。

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

進入應用程序的事件循環(huán)。

主要組件

uic: 用于從 .ui 文件加載 Qt 用戶界面。

QFileDialog: 提供打開和保存文件的對話框。

QMessageBox: 顯示消息對話框以獲取用戶反饋。

QSyntaxHighlighter: 用于實現(xiàn)文本編輯區(qū)的語法高亮功能。

代碼

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('狀態(tài)欄')
        # 加載好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):
        # 清空文本編輯區(qū)域
        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實現(xiàn)簡易文本編輯器的文章就介紹到這了,更多相關PyQt文本編輯器內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 使用Python生成詞云圖的詳細指南

    使用Python生成詞云圖的詳細指南

    在數(shù)據(jù)可視化領域,詞云圖是一種非常直觀且受歡迎的展示文本數(shù)據(jù)中關鍵詞頻率的方式,Python 中的wordcloud庫提供了一種簡單而強大的方法來生成詞云圖,本文就給大家介紹了使用Python生成詞云圖的詳細指南,需要的朋友可以參考下
    2024-12-12
  • Python調用Elasticsearch更新數(shù)據(jù)庫的操作方法

    Python調用Elasticsearch更新數(shù)據(jù)庫的操作方法

    Elasticsearch是一個分布式、多租戶的全文搜索引擎,支持HTTP Web接口和無模式的JSON文檔,本文介紹Python調用Elasticsearch更新數(shù)據(jù)庫的相關操作,感興趣的朋友一起看看吧
    2024-12-12
  • Blueprint實現(xiàn)路由分組及Flask中session的使用詳解

    Blueprint實現(xiàn)路由分組及Flask中session的使用詳解

    這篇文章主要為大家介紹了Blueprint實現(xiàn)路由分組及Flask中session的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • 一文帶你了解Python中pymysql的使用

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

    pymysql就是聯(lián)通mysql實現(xiàn)python窗口與mysql數(shù)據(jù)庫交互的庫,十分方便操作,這篇文章將詳細說明如何掌握并使用該庫,感興趣的可以了解一下
    2023-02-02
  • Python中Windows和macOS文件路徑格式不一致的解決方法

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

    在 Python 中,Windows 和 macOS 的文件路徑字符串格式不一致主要體現(xiàn)在路徑分隔符上,這種差異可能導致跨平臺代碼在處理文件路徑時出錯,下面我們看看如何解決吧
    2025-03-03
  • Python學習筆記(一)(基礎入門之環(huán)境搭建)

    Python學習筆記(一)(基礎入門之環(huán)境搭建)

    本系列為Python學習相關筆記整理所得,IT人,多學無害,多多探索,激發(fā)學習興趣,開拓思維,不求高大上,只求懂點皮毛,作為知識儲備,不至于落后太遠。本文主要介紹Python的相關背景,環(huán)境搭建。
    2014-06-06
  • 如何使用Python實現(xiàn)一個簡易的ORM模型

    如何使用Python實現(xiàn)一個簡易的ORM模型

    ORM(Object Relational Mapping)是一種程序設計技術,用于實現(xiàn)面向對象編程語言里不同類型系統(tǒng)的數(shù)據(jù)之間的轉換。本文將介紹如何使用Python實現(xiàn)一個簡易的ORM
    2021-05-05
  • 使用celery和Django處理異步任務的流程分析

    使用celery和Django處理異步任務的流程分析

    Celery是 一個專注于實時處理的任務隊列,它還支持任務調度。 Celery快速,簡單,高度可用且靈活。這篇文章主要介紹了使用celery和Django處理異步任務的流程分析,需要的朋友可以參考下
    2020-02-02
  • 在Python中定義函數(shù)并調用的操作步驟

    在Python中定義函數(shù)并調用的操作步驟

    這篇文章主要介紹了在Python中如何定義函數(shù)并調用它,函數(shù)的定義和調用是Python編程中最基本也是最重要的概念之一,掌握它們對于進行有效的Python編程至關重要,需要的朋友可以參考下
    2024-01-01
  • Pytest?Fixture參數(shù)講解及使用

    Pytest?Fixture參數(shù)講解及使用

    這篇文章主要介紹了Pytest之Fixture參數(shù)詳解及使用,本文結合實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01

最新評論