pyqt小案例實現簡易文本編輯器
分析
實現了一個簡單的文本編輯器,使用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 QRegularExpressionclass 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.textEditself.syntaxHighlighter = SyntaxHighlighter(self.textEdit.document())self.statusBar = self.ui.statusBarself.statusBar().showMessage('狀態欄')# 加載好ui文件之后再進行設置菜單欄menu = self.ui.menubarfile_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()