使用PyQt實(shí)現(xiàn)簡(jiǎn)易文本編輯器
分析
實(shí)現(xiàn)了一個(gè)簡(jiǎn)單的文本編輯器,使用PyQt5框架構(gòu)建。以下是代碼的主要功能和特點(diǎn):
主窗口類(lèi) (MyWindow)
繼承自 QWidget 類(lèi)。
使用 .ui 文件加載用戶(hù)界面布局。
設(shè)置窗口標(biāo)題、狀態(tài)欄消息等。
創(chuàng)建菜單欄及其子菜單項(xiàng)(文件和編輯),并綁定相應(yīng)的槽函數(shù)。
菜單操作
新建文件:清空文本編輯區(qū)域。
打開(kāi)文件:通過(guò)文件對(duì)話(huà)框選擇文件后讀取其內(nèi)容并顯示在文本編輯區(qū)域。
保存文件:通過(guò)文件對(duì)話(huà)框選擇保存位置并將文本編輯區(qū)域的內(nèi)容寫(xiě)入文件。
退出程序:關(guān)閉窗口前詢(xún)問(wèn)是否保存當(dāng)前文件。
語(yǔ)法高亮 (SyntaxHighlighter)
繼承自 QSyntaxHighlighter 類(lèi)。
定義關(guān)鍵字、注釋和字符串的格式規(guī)則。
實(shí)現(xiàn) highlightBlock 方法以根據(jù)定義的規(guī)則對(duì)每一行文本進(jìn)行高亮處理。
運(yùn)行程序
創(chuàng)建 QApplication 實(shí)例。
初始化 MyWindow 窗口實(shí)例并展示。
進(jìn)入應(yīng)用程序的事件循環(huán)。
主要組件
uic: 用于從 .ui 文件加載 Qt 用戶(hù)界面。
QFileDialog: 提供打開(kāi)和保存文件的對(duì)話(huà)框。
QMessageBox: 顯示消息對(duì)話(huà)框以獲取用戶(hù)反饋。
QSyntaxHighlighter: 用于實(shí)現(xiàn)文本編輯區(qū)的語(yǔ)法高亮功能。
代碼
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("文本編輯器") # 修改標(biāo)題的名稱(chēng)
self.textEdit = self.ui.textEdit
self.syntaxHighlighter = SyntaxHighlighter(self.textEdit.document())
self.statusBar = self.ui.statusBar
self.statusBar().showMessage('狀態(tài)欄')
# 加載好ui文件之后再進(jìn)行設(shè)置菜單欄
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)
# 打開(kāi)文件動(dòng)作
self.open = file_menu.addAction("打開(kāi)")
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("復(fù)制")
edit_menu.addAction("粘貼")
edit_menu.addAction("剪切")
def newFile(self):
# 清空文本編輯區(qū)域
self.textEdit.clear()
self.statusBar().showMessage('新文件')
def openFile(self):
# 打開(kāi)文件對(duì)話(huà)框,讀取文件內(nèi)容,將其顯示在textEdit中
fileName, _ = QFileDialog.getOpenFileName(self, '打開(kāi)文件', '', '文本文件 (*.txt);;所有文件 (*)')
if fileName:
with open(fileName, 'r', encoding='utf-8') as file:
self.textEdit.setText(file.read())
self.statusBar().showMessage('打開(kāi)新文件')
def saveFile(self):
# 保存文件對(duì)話(huà)框,打開(kāi)一個(gè)文件,將textEdit中的內(nèi)容寫(xiě)進(jìn)去
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):
# 關(guān)閉窗口時(shí)提示保存
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()圖示

到此這篇關(guān)于使用PyQt實(shí)現(xiàn)簡(jiǎn)易文本編輯器的文章就介紹到這了,更多相關(guān)PyQt文本編輯器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python調(diào)用Elasticsearch更新數(shù)據(jù)庫(kù)的操作方法
Elasticsearch是一個(gè)分布式、多租戶(hù)的全文搜索引擎,支持HTTP Web接口和無(wú)模式的JSON文檔,本文介紹Python調(diào)用Elasticsearch更新數(shù)據(jù)庫(kù)的相關(guān)操作,感興趣的朋友一起看看吧2024-12-12
Blueprint實(shí)現(xiàn)路由分組及Flask中session的使用詳解
這篇文章主要為大家介紹了Blueprint實(shí)現(xiàn)路由分組及Flask中session的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11
Python中Windows和macOS文件路徑格式不一致的解決方法
在 Python 中,Windows 和 macOS 的文件路徑字符串格式不一致主要體現(xiàn)在路徑分隔符上,這種差異可能導(dǎo)致跨平臺(tái)代碼在處理文件路徑時(shí)出錯(cuò),下面我們看看如何解決吧2025-03-03
Python學(xué)習(xí)筆記(一)(基礎(chǔ)入門(mén)之環(huán)境搭建)
本系列為Python學(xué)習(xí)相關(guān)筆記整理所得,IT人,多學(xué)無(wú)害,多多探索,激發(fā)學(xué)習(xí)興趣,開(kāi)拓思維,不求高大上,只求懂點(diǎn)皮毛,作為知識(shí)儲(chǔ)備,不至于落后太遠(yuǎn)。本文主要介紹Python的相關(guān)背景,環(huán)境搭建。2014-06-06
如何使用Python實(shí)現(xiàn)一個(gè)簡(jiǎn)易的ORM模型
ORM(Object Relational Mapping)是一種程序設(shè)計(jì)技術(shù),用于實(shí)現(xiàn)面向?qū)ο缶幊陶Z(yǔ)言里不同類(lèi)型系統(tǒng)的數(shù)據(jù)之間的轉(zhuǎn)換。本文將介紹如何使用Python實(shí)現(xiàn)一個(gè)簡(jiǎn)易的ORM2021-05-05
使用celery和Django處理異步任務(wù)的流程分析
Celery是 一個(gè)專(zhuān)注于實(shí)時(shí)處理的任務(wù)隊(duì)列,它還支持任務(wù)調(diào)度。 Celery快速,簡(jiǎn)單,高度可用且靈活。這篇文章主要介紹了使用celery和Django處理異步任務(wù)的流程分析,需要的朋友可以參考下2020-02-02
在Python中定義函數(shù)并調(diào)用的操作步驟
這篇文章主要介紹了在Python中如何定義函數(shù)并調(diào)用它,函數(shù)的定義和調(diào)用是Python編程中最基本也是最重要的概念之一,掌握它們對(duì)于進(jìn)行有效的Python編程至關(guān)重要,需要的朋友可以參考下2024-01-01

