使用PyQt實現(xiàn)簡易文本編輯器
分析
實現(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調用Elasticsearch更新數(shù)據(jù)庫的操作方法
Elasticsearch是一個分布式、多租戶的全文搜索引擎,支持HTTP Web接口和無模式的JSON文檔,本文介紹Python調用Elasticsearch更新數(shù)據(jù)庫的相關操作,感興趣的朋友一起看看吧2024-12-12Blueprint實現(xiàn)路由分組及Flask中session的使用詳解
這篇文章主要為大家介紹了Blueprint實現(xiàn)路由分組及Flask中session的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-11-11Python中Windows和macOS文件路徑格式不一致的解決方法
在 Python 中,Windows 和 macOS 的文件路徑字符串格式不一致主要體現(xiàn)在路徑分隔符上,這種差異可能導致跨平臺代碼在處理文件路徑時出錯,下面我們看看如何解決吧2025-03-03Python學習筆記(一)(基礎入門之環(huán)境搭建)
本系列為Python學習相關筆記整理所得,IT人,多學無害,多多探索,激發(fā)學習興趣,開拓思維,不求高大上,只求懂點皮毛,作為知識儲備,不至于落后太遠。本文主要介紹Python的相關背景,環(huán)境搭建。2014-06-06