pyqt添加菜单栏

参考:
https://blog.csdn.net/seniorwizard/article/details/109820641

import sys
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtCore import Qt
from PyQt5.QtWidgets import (QApplication, QMainWindow, QMenuBar, QMenu, QAction, QPlainTextEdit, QStyle, QFileDialog,QMessageBox)class DemoNotepad(QMainWindow):def __init__(self, parent=None):super(DemoNotepad, self).__init__(parent)       # 设置窗口标题self.setWindowTitle('实战PyQt5: QAction Demo-记事本')      # 设置窗口大小self.resize(480, 360)self.path = Noneself.initUi()def initUi(self):#设置一个文本编辑器作为中心小部件self.txtEditor = QPlainTextEdit(self)  self.setCentralWidget(self.txtEditor)self.initMenuBar()def initMenuBar(self):menuBar = self.menuBar()       fileMenu = menuBar.addMenu('文件(&F)')editMenu = menuBar.addMenu('编辑(&E)')formatMenu = menuBar.addMenu('格式(&O)')helpMenu = menuBar.addMenu('帮助(&H)')style = QApplication.style()# ==== 文件操作部分 ==== ##新建文件aFileNew = QAction('新建(&N)', self)#添加一个图标aFileNew.setIcon(style.standardIcon(QStyle.SP_FileIcon))#添加快捷键aFileNew.setShortcut(Qt.CTRL + Qt.Key_N)aFileNew.triggered.connect(self.onFileNew)fileMenu.addAction(aFileNew)   #打开文件aFileOpen = QAction('打开(&O)...', self)aFileOpen.setIcon(style.standardIcon(QStyle.SP_DialogOpenButton))aFileOpen.setShortcut(Qt.CTRL + Qt.Key_O)aFileOpen.triggered.connect(self.onFileOpen)fileMenu.addAction(aFileOpen)      #保存aFileSave = QAction('保存(&S)', self) aFileSave.setIcon(style.standardIcon(QStyle.SP_DialogSaveButton)) aFileSave.setShortcut(Qt.CTRL + Qt.Key_S)aFileSave.triggered.connect(self.onFileSave)  fileMenu.addAction(aFileSave)        #另存为aFileSaveAs = QAction('另存为(&A)...', self)aFileSaveAs.triggered.connect(self.onFileSaveAs)fileMenu.addAction(aFileSaveAs)       #间隔线fileMenu.addSeparator()        #退出菜单aFileExit = QAction('退出(&X)', self) aFileExit.triggered.connect(self.close)fileMenu.addAction(aFileExit)# ==== 编辑部分 ==== ##撤销编辑aEditUndo = QAction('撤销(&U)',self)aEditUndo.setShortcut(Qt.CTRL + Qt.Key_Z)aEditUndo.triggered.connect(self.txtEditor.undo)editMenu.addAction(aEditUndo)#恢复编辑aEditRedo = QAction('恢复(&R)', self)aEditRedo.setShortcut(Qt.CTRL + Qt.Key_Y)aEditUndo.triggered.connect(self.txtEditor.redo)editMenu.addAction(aEditRedo)#间隔线editMenu.addSeparator()        #剪切操作aEditCut = QAction('剪切(&T)', self)aEditCut.setShortcut(Qt.CTRL + Qt.Key_X)aEditCut.triggered.connect(self.txtEditor.cut)editMenu.addAction(aEditCut)#复制操作aEditCopy = QAction('复制(&C)', self)aEditCopy.setShortcut(Qt.CTRL + Qt.Key_C)aEditCopy.triggered.connect(self.txtEditor.copy)editMenu.addAction(aEditCopy)#粘贴操作aEditPaste = QAction('粘贴(&P)', self)aEditPaste.setShortcut(Qt.CTRL + Qt.Key_V)aEditPaste.triggered.connect(self.txtEditor.paste)editMenu.addAction(aEditPaste)#删除操作aEditDel = QAction('删除(&L)', self)aEditDel.setShortcut(Qt.Key_Delete)aEditDel.triggered.connect(self.onEditDelete)editMenu.addAction(aEditDel)#添加分割线editMenu.addSeparator()#全选操作aEditSelectAll = QAction('全选(&A)', self)aEditSelectAll.setShortcut(Qt.CTRL + Qt.Key_A)aEditSelectAll.triggered.connect(self.txtEditor.selectAll)editMenu.addAction(aEditSelectAll)# ==== 格式设置部分 ==== #aFmtAutoLine = QAction('自动换行(&W)', self)aFmtAutoLine.setCheckable(True)aFmtAutoLine.setChecked(True)aFmtAutoLine.triggered[bool].connect(self.onFormatAutoLine)formatMenu.addAction(aFmtAutoLine)# ==== 帮助部分 ==== #aHelpAbout = QAction('关于(&A)...', self)aHelpAbout.triggered.connect(self.onHelpAbout)helpMenu.addAction(aHelpAbout)def msgCritical(self, strInfo):dlg = QMessageBox(self)dlg.setIcon(QMessageBox.Critical)dlg.setText(strInfo)dlg.show()def onFileNew(self):self.txtEditor.clear()def onFileOpen(self):path,_ = QFileDialog.getOpenFileName(self, '打开文件', '', '文本文件 (*.txt)')if path:try:with open(path, 'rU') as f:text = f.read()except Exception as e:self.msgCritical(str(e))else:self.path = pathself.txtEditor.setPlainText(text)def onFileSave(self):if self.path is None:return self.onFileSaveAs()self._saveToPath(self.path)def onFileSaveAs(self):path,_ = QFileDialog.getSaveFileName(self, '保存文件', '', '文本文件 (*.txt)')if not path:returnself._saveToPath(path)def _saveToPath(self, path):text = self.txtEdit.toPlainText()try:with open(path, 'w') as f:f.write(text)except Exception as e:self.msgCritical(str(e))else:self.path = pathdef onEditDelete(self):tc = self.txtEditor.textCursor()#tc.select(QtGui.QTextCursor.BlockUnderCursor) 这样删除一行tc.removeSelectedText()def onFormatAutoLine(self, autoLine):if autoLine:self.txtEditor.setLineWrapMode(QPlainTextEdit.WidgetWidth)else:self.txtEditor.setLineWrapMode(QPlainTextEdit.NoWrap)def onHelpAbout(self):QMessageBox.information(self, '实战PyQt5', 'PyQt5实现的文本编辑器演示版')if __name__ == '__main__':app = QApplication(sys.argv)window = DemoNotepad()window.show()sys.exit(app.exec()) 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/651543.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HarmonyOS鸿蒙ArkTS,封装http网络请求

HarmonyOS鸿蒙ArkTS,封装http网络请求 前提: 要想使用http请求,系统必须要具备ohos.permission.INTERNET权限,在model.json5文件中的module模块下添加如下请求权限: 在module.json5文件中 配置 "requestPermi…

踩坑(6)Redisson调用unlockAsync方法释放锁失败

问题描述 通过redisson的lockAsync异步方法获取到锁之后&#xff0c;再业务执行完成后调用lock.unlockAsync()无法释放当前锁&#xff0c;导致后续的方法被阻塞 public void asyncLock() {RLock lock redissonClient.getLock("asyncLock");RFuture<Void> fut…

LeetCode 热题 100 | 矩阵

目录 1 73. 矩阵置零 2 54. 螺旋矩阵 3 48. 旋转图像 4 240. 搜索二维矩阵 II 菜鸟做题第二周&#xff0c;语言是 C 1 73. 矩阵置零 解题思路&#xff1a; 遍历矩阵&#xff0c;寻找等于 0 的元素&#xff0c;记录对应的行和列将被记录的行的元素全部置 0将被记录的…

k8s 进阶实战笔记 | Scheduler 调度策略总结

文章目录 Scheduler 调度策略总结调度原理和过程调度策略nodeSelect亲和性和反亲和性NodeAffinify亲和验证PodAffinity 亲和验证PodAntiAffinity 反亲和验证污点与容忍跳过 Scheduler 调度策略 调度策略场景总结 Scheduler 调度策略总结 调度原理和过程 Scheduler 一直监听着…

k8s Ingress部署应用

Deployment(部署) Deployment处于master节点&#xff0c;master会选择合适的work节点创建Container Container会被包含在Pod中 通过k8s部署一个nginx kubectl create deployment my-nginx --imagenginx创建一个tomcat 镜像 创建一个tomcat-svc.yaml文件 创建service类型…

【心得】java JNDI配合RMI实现注入个人笔记

目录 JNDI RMI 基本概念 RMI 基本逻辑 恶意利用 JNDI注入RMI实现攻击 JNDI Java Naming and Directory Interface Java 命令和目录接口 让配置参数 和 代码 解耦的规范或者思想 低耦合 高内聚 Name 命名 java对象 通过 命名 绑定到 容器环境 java对象和一个特定的…

Java技术栈 —— Kafka入门(一)

Java技术栈 —— Kafka入门&#xff08;一&#xff09; 一、什么是Kafka&#xff1f;二、如何安装Kafka&#xff1f; 一、什么是Kafka&#xff1f; Kafka是一种消息队列&#xff0c;通过订阅-发布机制可以实现解耦合&#xff0c;用异步处理代替同步处理[1] 。&#xff08;理解这…

REVIT二次开发万能刷

将这两个参数赋予其他参数 步骤2 将来做个可以调控的版本 using System; using System.Collections.Generic; using System.Lin

如何把word檔案自動化

1.安裝 pip install jojo-office ( 安裝這個) 2.讀取表格內容與文章內容&#xff0c;範例如下 import office from docx import Document replace{“{user_name}”:“陳彥甫”, “{tele}”:“0912882881”} docDocument(“template.docx”) tabledoc.tables[0] print(“ii:”…

《Python 简易速速上手小册》第7章:高级 Python 编程(基于最新版 Python3.12 编写)

注意&#xff1a;本《Python 简易速速上手小册》 核心目的在于让零基础新手「快速构建 Python 知识体系」 文章目录 <mark >注意&#xff1a;本《Python 简易速速上手小册》<mark >核心目的在于让零基础新手「快速构建 Python 知识体系」 7.1 装饰器和闭包7.1.1 装…

华为机考入门python3--(4)牛客4-字符串分隔

分类&#xff1a;字符串 知识点&#xff1a; 复制符号* 复制3个0 0*3 000 字符串截取 截取第i位到j-1位 str[i:j] 题目来自【牛客】 input_str input().strip()# 先补齐 if len(input_str) % 8 ! 0: input_str 0 * (8 - len(input_str) % 8) # 每8个分 out…

R语言【taxlist】——indended_list():将层级结构输出为缩进列表

Package taxlist version 0.2.4 Description 将 taxlist 对象打印分类层次结构&#xff08;等级和父子关系&#xff09;输出为缩进列表。 Usage indented_list(object, ...)## S4 method for signature taxlist indented_list(object,filter,keep_children TRUE,keep_parent…

uniapp微信小程序-请求二次封装(直接可用)

一、请求封装优点 代码重用性&#xff1a;通过封装请求&#xff0c;你可以在整个项目中重用相同的请求逻辑。这样一来&#xff0c;如果 API 发生变化或者需要进行优化&#xff0c;你只需在一个地方修改代码&#xff0c;而不是在每个使用这个请求的地方都进行修改。 可维护性&a…

JAVA学习笔记三

1.java执行流程分析 2.什么是编译 javac Hello.java 1.有了java源文件&#xff0c;通过编译器将其编译成JVM可以识别的字节码文件 2.在该源文件目录下&#xff0c;通过javac编译工具对Hello.java文件进行编译 3.如果程序没有错误&#xff0c;没有任何提示&#xff0c;但在…

【Spring连载】使用Spring访问 Apache Kafka(十八)----非阻塞重试

【Spring连载】使用Spring访问 Apache Kafka&#xff08;十八&#xff09;----非阻塞重试Non-Blocking Retries 一、这种模式是如何运作的How The Pattern Works二、回退延迟精度Back Off Delay Precision概述和保证Overview and Guarantees 三、配置Configuration四、Programm…

Linux下的进程操作

进程概念 ps -elf&#xff1a;查看操作系统的所有进程&#xff08;Linux命令&#xff09; ctrl z&#xff1a;把进程切换到后台 crtl c&#xff1a;结束进程 fg&#xff1a;把进程切换到前台 获取进程进程号和父进程号 函数原型&#xff1a; pid_t getpid(void); //pid_t…

文件上传之大文件分块上传进度控制处理

在分块上传内容结束以后的事件监听&#xff0c;我们会实现 unlinkSync 删除临时文件操作&#xff0c;那么试想一下&#xff0c;在这个事件监听中&#xff0c;我们是否可以通过totalChunks以及currentChunk获取当前上传的进度情况呢&#xff1f; 后端 upload上传接口&#xff…

【GitHub项目推荐--十六进制编辑器】【转载】

一款名为 ImHex 的十六进制编辑器获得了 15.3k 的 Star。十六进制编辑器可以让你以十六进制的形式查看或编辑文件的二进制数据&#xff0c;并用较为友好的界面来编辑二进制数据&#xff0c;和常见的十六进制编辑器 GNOME Hex Editor 等不一样&#xff0c;ImHex 功能非常强大&am…

Unity 光照

光照烘培 光照模式切换为 Baked 或 Mixed&#xff0c;Baked 模式完全使用光照贴图模拟光照&#xff0c;运行时修改光照颜色不生效&#xff0c;Mixed 模式也使用光照贴图&#xff0c;并且进行一些实时运算&#xff0c;运行时修改光照颜色会生效 受光照影响的物体勾选 Contribute…

02-opencv-上

机器视觉概述 机器视觉是人工智能正在快速发展的一个分支。简单说来&#xff0c;机器视觉就是用机器代替人眼来做测量和判断。机器视觉系统是通过机器视觉产品(即图像摄取装置&#xff0c;分CMOS和CCD两种)将被摄取目标转换成图像信号&#xff0c;传送给专用的图像处理系统&…