PyQt5笔记之菜单栏
菜单栏
创建单层菜单
import sys
from PyQt5.QtWidgets import QApplication, QAction, QMainWindow
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.statusBar().showMessage("状态栏:无")
self.setWindowTitle("单层菜单栏")
self.setMinimumSize(160, 160)
self.resize(360, 280)
self.createActions()
self.createMenus()
def createActions(self):
self.newAct = QAction("新建", self)
self.newAct.setShortcut("Ctrl+N")
self.newAct.setStatusTip("状态栏:新建")
self.newAct.triggered.connect(self.new)
self.openAct = QAction("打开", self)
self.openAct.setShortcut("Ctrl+O")
self.openAct.setStatusTip("状态栏:打开")
self.openAct.triggered.connect(self.openf)
self.exitAct = QAction("退出", self)
self.exitAct.setShortcut("Ctrl+E")
self.exitAct.setStatusTip("状态栏:退出")
self.exitAct.triggered.connect(self.close)
def createMenus(self):
fileMenu = self.menuBar().addMenu("文件 (&F)")
fileMenu.addAction(self.newAct)
fileMenu.addAction(self.openAct)
fileMenu.addSeparator()
fileMenu.addAction(self.exitAct)
def new(self):
pass
def openf(self):
pass
if __name__ == '__main__':
app = QApplication(sys.argv)
win = MainWindow()
win.show()
sys.exit(app.exec_())
代码分析:
11行
:创建一个状态栏,并显示消息
self.statusBar().showMessage("状态栏:无")
12行
:设置应用的标题
self.setWindowTitle("单层菜单栏")
13行
:设置窗口能缩小的最小值
self.setMinimumSize(160, 160)
14行
:设置窗口的默认大小
self.resize(360, 280)
19行
:创建一个动作
self.newAct = QAction("新建", self)
20行
:为该动作设置快捷键
self.newAct.setShortcut("Ctrl+N")
21行
:为该动作设置状态栏显示的信息
self.newAct.setStatusTip("状态栏:新建")
22行
:为该动作的triggered
信号绑定槽 (self.new
)
self.newAct.triggered.connect(self.new)
32行
:这里的槽直接使用就好,不用自己再创建,因为有这个方法了;self.close
= QMainWindow.close()
self.exitAct.triggered.connect(self.close)
35行
:为主窗口创建一个菜单栏,并添加一个名为文件的菜单;(&F)
表示可以使用快捷键Alt+F
来快速选择它
fileMenu = self.menuBar().addMenu("文件 (&F)")
36行
:为菜单添加一个动作 (self.newAct
),改动作已在19行
创建并设置好了。
fileMenu.addAction(self.newAct)
38行
:添加一个分隔符
fileMenu.addSeparator()
创建多层菜单
import sys
from PyQt5.QtWidgets import QApplication, QAction, QMainWindow
from PyQt5.QtGui import QKeySequence
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.statusBar().showMessage("状态栏:无")
self.setWindowTitle("单层菜单栏")
self.setMinimumSize(160, 160)
self.resize(360, 280)
self.createActions()
self.createMenus()
def createActions(self):
self.newAct = QAction("新建", self)
self.newAct.setShortcut("Ctrl+N")
self.newAct.setStatusTip("状态栏:新建")
self.newAct.triggered.connect(self.new)
self.openAct = QAction("打开", self)
self.openAct.setShortcut("Ctrl+O")
self.openAct.setStatusTip("状态栏:打开")
self.openAct.triggered.connect(self.openf)
self.exitAct = QAction("退出", self)
self.exitAct.setShortcut("Ctrl+E")
self.exitAct.setStatusTip("状态栏:退出")
self.exitAct.triggered.connect(self.close)
self.setAct = QAction("设置", self)
self.setAct.setStatusTip("状态栏:设置")
def createMenus(self):
fileMenu = self.menuBar().addMenu("文件 (&F)")
fileMenu.addAction(self.newAct)
fileMenu.addAction(self.openAct)
moreMenu = fileMenu.addMenu("更多... (&M)") # 在菜单中添加一个菜单
moreMenu.addAction(self.setAct) # 位子菜单添加动作
fileMenu.addSeparator()
fileMenu.addAction(self.exitAct)
def new(self):
pass
def openf(self):
pass
if __name__ == '__main__':
app = QApplication(sys.argv)
win = MainWindow()
win.show()
sys.exit(app.exec_())
只是添加了几条代码,已经注释,也可以看 创建单层菜单
如果要创建更多层菜单,只需要向菜单中添加菜单即可
例如:
Amenu = self.menuBar().addMenu("父菜单")
Bmenu = Amenu.addMenu("第一层")
Cmenu = Bmenu.addMenu("第二层")
右键打开菜单
import sys
from PyQt5.QtWidgets import QMainWindow, QAction, QMenu, QApplication
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.cutAct = QAction("&Cut", self)
self.copyAct = QAction("&Copy", self)
self.pasteAct = QAction("&Paste", self)
def contextMenuEvent(self, event):
menu = QMenu(self)
menu.addAction(self.cutAct)
menu.addAction(self.copyAct)
menu.addAction(self.pasteAct)
menu.exec(event.globalPos())
if __name__ == '__main__':
app = QApplication(sys.argv)
win = MainWindow()
win.show()
sys.exit(app.exec_())
官方菜单实例
源码是C++
语言的。研究了半天,还好长得差不多,Python
算是写出来了。
官方菜单示例:https://doc.qt.io/qt-5/qtwidgets-mainwindows-menus-example.html# (了解更多就看看这个吧)
官方示例源码:https://code.qt.io/cgit/qt/qtbase.git/tree/examples/widgets/mainwindows/menus/mainwindow.cpp?h=5.13
import sys
from PyQt5.QtWidgets import QMessageBox, QActionGroup, QVBoxLayout, QFrame, QLabel, QSizePolicy, QApplication, QMenu, QMenuBar, QMainWindow, QWidget, QAction
from PyQt5.QtCore import Qt
from PyQt5.QtGui import QKeySequence, QFont
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
widget = QWidget(self)
self.setCentralWidget(widget)
self.topFiller = QWidget(self)
self.topFiller.setSizePolicy(QSizePolicy.Expanding, QSizePolicy.Expanding)
self.infolabel = QLabel("<i>Choose a menu option, or right-click to invoke a context menu</i>")
self.infolabel.setFrameStyle(QFrame.StyledPanel | QFrame.Sunken)
self.infolabel.setAlignment(Qt.AlignCenter)
self.bottomFiller = QWidget(self)
self.bottomFiller.setSizePolicy(QSizePolicy.Expanding, QSizePolicy.Expanding)
self.layout = QVBoxLayout(self)
self.layout.setContentsMargins(5, 5, 5, 5)
self.layout.addWidget(self.topFiller)
self.layout.addWidget(self.infolabel)
self.layout.addWidget(self.bottomFiller)
widget.setLayout(self.layout)
self.createActions()
self.createMenus()
self.statusBar().showMessage("A context menu is available by right-clicking")
self.setWindowTitle("Menu")
self.setMinimumSize(160, 160)
self.resize(480, 320)
def contextMenuEvent(self, event):
menu = QMenu(self)
menu.addAction(self.cutAct)
menu.addAction(self.copyAct)
menu.addAction(self.pasteAct)
menu.exec(event.globalPos())
def createActions(self):
self.newAct = QAction("&New", self)
self.newAct.setShortcuts(QKeySequence.New)
self.newAct.setStatusTip("Create a new file")
self.newAct.triggered.connect(self.newFile)
self.openAct = QAction("&Opem", self)
self.openAct.setShortcuts(QKeySequence.Open)
self.openAct.setStatusTip("Open an existing file")
self.openAct.triggered.connect(self.opens)
self.saveAct = QAction("&Save", self)
self.saveAct.setShortcuts(QKeySequence.Save)
self.saveAct.setStatusTip("")
self.saveAct.triggered.connect(self.save)
self.printsAct = QAction("&Print", self)
self.printsAct.setShortcuts(QKeySequence.Print)
self.printsAct.setStatusTip("Print the document")
self.printsAct.triggered.connect(self.prints)
self.exitAct = QAction("&Exit", self)
self.exitAct.setShortcuts(QKeySequence.Quit)
self.exitAct.setStatusTip("Exit the application")
self.exitAct.triggered.connect(self.close)
self.undoAct = QAction("&Undo", self)
self.undoAct.setShortcuts(QKeySequence.Undo)
self.undoAct.setStatusTip("Undo the last operation")
self.undoAct.triggered.connect(self.undo)
self.redoAct = QAction("&Redo", self)
self.redoAct.setShortcuts(QKeySequence.Redo)
self.redoAct.setStatusTip("Redo the last operation")
self.redoAct.triggered.connect(self.redo)
self.cutAct = QAction("&Cut", self)
self.cutAct.setShortcuts(QKeySequence.Cut)
self.cutAct.setStatusTip("Cut the current selection's contents to the clipboard")
self.cutAct.triggered.connect(self.cut)
self.copyAct = QAction("&Copy", self)
self.copyAct.setShortcuts(QKeySequence.Copy)
self.copyAct.setStatusTip("Copy the current selection's contents to the clipboard")
self.copyAct.triggered.connect(self.copy)
self.pasteAct = QAction("&Paste", self)
self.pasteAct.setShortcuts(QKeySequence.Paste)
self.pasteAct.setStatusTip("Paste the clipboard's contents into the current selection")
self.pasteAct.triggered.connect(self.paste)
self.boldAct = QAction("&Bold", self)
self.boldAct.setShortcuts(QKeySequence.Bold)
self.boldAct.setStatusTip("Make the text bold")
self.boldAct.triggered.connect(self.bold)
self.boldFont = QFont()
self.boldFont.setBold(True)
self.boldAct.setFont(self.boldFont)
self.italicAct = QAction("&Italic", self)
self.italicAct.setCheckable(True)
self.italicAct.setShortcut(QKeySequence.Italic)
self.italicAct.setStatusTip("Make the text italic")
self.italicAct.triggered.connect(self.italic)
self.italicFont = QFont()
self.italicFont.setItalic(True)
self.italicAct.setFont(self.italicFont)
self.setLineSpacingAct = QAction("Set &Line Spacing...", self)
self.setLineSpacingAct.setStatusTip("Change the gap between the lines of a paragraph")
self.setLineSpacingAct.triggered.connect(self.setParagraphSpacing)
self.setParagraphSpacingAct = QAction("Set &Paragraph Spacing...", self)
self.setParagraphSpacingAct.setStatusTip("Change the gap between paragraphs")
self.setParagraphSpacingAct.triggered.connect(self.setParagraphSpacing)
self.aboutAct = QAction("&About", self)
self.aboutAct.setStatusTip("Show the application's About box")
self.aboutAct.triggered.connect(self.about)
self.aboutQtAct = QAction("About &Qt", self)
self.aboutQtAct.setStatusTip("Show the Qt library's About box")
self.aboutQtAct.triggered.connect(QApplication.aboutQt)
self.aboutQtAct.triggered.connect(self.aboutQt)
self.leftAlignAct = QAction("&Left Align", self)
self.leftAlignAct.setCheckable(True)
self.leftAlignAct.setShortcut("Ctrl+L")
self.leftAlignAct.setStatusTip("Left align the selected tetx")
self.leftAlignAct.triggered.connect(self.leftAlign)
self.rightAlignAct = QAction("&Right Align", self)
self.rightAlignAct.setCheckable(True)
self.rightAlignAct.setShortcut("Ctrl+R")
self.rightAlignAct.setStatusTip("Right algin the selected text")
self.rightAlignAct.triggered.connect(self.rightAlign)
self.justifyAct = QAction("&Justify", self)
self.justifyAct.setCheckable(True)
self.justifyAct.setShortcut("Ctrl+J")
self.justifyAct.setStatusTip("Justify the selected text")
self.justifyAct.triggered.connect(self.justify)
self.centerAct = QAction("&Center", self)
self.centerAct.setCheckable(True)
self.centerAct.setShortcut("Ctrl+E")
self.centerAct.setStatusTip("Center the selected text")
self.centerAct.triggered.connect(self.center)
self.alignmentGroup = QActionGroup(self)
self.alignmentGroup.addAction(self.leftAlignAct)
self.alignmentGroup.addAction(self.rightAlignAct)
self.alignmentGroup.addAction(self.justifyAct)
self.alignmentGroup.addAction(self.centerAct)
self.leftAlignAct.setChecked(True)
def createMenus(self):
fileMenu = self.menuBar().addMenu("&File")
fileMenu.addAction(self.newAct)
fileMenu.addAction(self.openAct)
fileMenu.addAction(self.saveAct)
fileMenu.addAction(self.printsAct)
fileMenu.addSeparator()
fileMenu.addAction(self.exitAct)
editMenu = self.menuBar().addMenu("&Edit")
editMenu.addAction(self.undoAct)
editMenu.addAction(self.redoAct)
editMenu.addSeparator()
editMenu.addAction(self.cutAct)
editMenu.addAction(self.copyAct)
editMenu.addAction(self.pasteAct)
editMenu.addSeparator()
helpMenu = self.menuBar().addMenu("&Help")
helpMenu.addAction(self.aboutAct)
helpMenu.addAction(self.aboutQtAct)
formatMenu = editMenu.addMenu("&Help")
formatMenu.addAction(self.boldAct)
formatMenu.addAction(self.italicAct)
formatMenu.addSeparator().setText("Alignment")
formatMenu.addAction(self.leftAlignAct)
formatMenu.addAction(self.rightAlignAct)
formatMenu.addAction(self.justifyAct)
formatMenu.addAction(self.centerAct)
formatMenu.addSeparator()
formatMenu.addAction(self.setLineSpacingAct)
formatMenu.addAction(self.setParagraphSpacingAct)
def newFile(self):
self.infolabel.setText("Invoked <b>File|New</b>")
def opens(self):
self.infolabel.setText("Invoked <b>File|Open</b>")
def save(self):
self.infolabel.setText("Invoked <b>File|Save</b>")
def prints(self):
self.infolabel.setText("Invoked <b>File|Print</b>")
def undo(self):
self.infolabel.setText("Invoked <b>Edit|Undo</b>")
def redo(self):
self.infolabel.setText("Invoked <b>Edit|Redo</b>")
def cut(self):
self.infolabel.setText("Invoked <b>Edit|Cut</b>")
def copy(self):
self.infolabel.setText("Invoked <b>Edit|Copy</b>")
def paste(self):
self.infolabel.setText("Invoked <b>Edit|Paste</b>")
def bold(self):
self.infolabel.setText("Invoked <b>Edit|Format|Bold</b>")
def italic(self):
self.infolabel.setText("Invoked <b>Edit|Format|Italic</b>")
def leftAlign(self):
self.infolabel.setText("Invoked <b>Edit|Format|Left Align</b>")
def rightAlign(self):
self.infolabel.setText("Invoked <b>Edit|Format|Right Align</b>")
def justify(self):
self.infolabel.setText("Invoked <b>Edit|Format|Justify</b>")
def center(self):
self.infolabel.setText("Invoked <b>Edit|Format|Center</b>")
def setLineSpacing(self):
self.infolabel.setText("Invoked <b>Edit|Format|Set Line Spacing</b>")
def setParagraphSpacing(self):
self.infolabel.setText("Invoked <b>Edit|Format|Set Paragraph Spacing</b>")
def about(self):
self.infolabel.setText("Invoked <b>Help|About</b>")
QMessageBox.information(self, "About Menu", "The <b>Menu</b> example shows how to create menu-bar menus and context menus.")
def aboutQt(self):
self.infolabel.setText("Invoked <b>Help|About Qt</b>")
if __name__ == '__main__':
app = QApplication(sys.argv)
win = MainWindow()
win.show()
sys.exit(app.exec_())
菜单常用方法
方法 | 案例 | 描述 |
---|---|---|
QMenu().setIcon() |
QMenu().setIcon(QIcon("D:\\.cookie.png")) |
为菜单设置一个图标,默认预留一个空位 |
QMenu().setSeparatorsCollapsible() |
QMenu().setSeparatorsCollapsible(False) |
是否将多个连续的分隔符合并为一个;True 表示合并,False 表示不合并,默认为True |
QMenu().setTearOffEnabled() |
QMenu.setTearOffEnabled(True) |
菜单能否被撕下(移动,变成独立的小窗口),True 可以撕下,False 不可以,默认为False |
QMenu().setTitle() |
QMenu().setTitle("文件 (&F)") |
设置菜单的标题 |
QMenu().aboutToShow() |
QMenu().aboutToShow.connect(self.func) |
将该信号绑定到一个槽;当你点击菜单后显示出来就会发送此信号(不常用) |
QMenu().aboutToHide() |
QMenu().aboutToHide.connect(self.func) |
将该信号绑定到一个槽;当你的菜单隐藏后就会发送此信号(不常用) |
QMenu().hovered() |
QMenu().hovered.connect(self.func) |
将该信号绑定到一个槽;当你的鼠标滑过或悬停在菜单时就会发送此信号(不建议用) |
QMenu().triggered() |
QMenu().triggered.connect(self.func) |
将该信号绑定到一个槽;当你点击了菜单下的动作(QAction )时会发送此信号(注意:菜单下的菜单不会被触发) |
QMenu().addSeparator() |
QMenu().addSeparator() |
为菜单添加分隔符 |
QMenu().setShortcut() |
QMenu().setShortcut("Ctrl+A") |
设置快捷键 |
QMenu().clear() |
QMenu().clear() |
清除菜单 |
PyQt5笔记之菜单栏的更多相关文章
- 三、PyQt5不同方法创建菜单栏、工具栏和状态栏
创建菜单栏.工具栏和状态栏可以直接通过代码实现,也可以通过Qt Designer中的属性编辑器等实现.通过两种方法的学习可以加深理解,更好的掌握PyQt5. 一.菜单栏与状态栏 状态栏的设置比较简单, ...
- PyQt5 笔记(02):嵌套布局
如前一篇笔记,我们还是只讨论两层嵌套布局的情况. 前面的布局有一个缺点:有三个内层布局,则需要三个空部件.那若有十个内层布局呢?显然会让人不舒服. 刚才在玩 Qt Designer 时,发现了一个更好 ...
- PyQt5笔记
PyQt5 窗口类继承QMainWindow. 1.消息盒子QMessageBox 弹出一个窗口,根据选择的不同执行不同的操作.比如点击关闭后,实用消息盒子确认是否关闭. # 关闭QWidget将产生 ...
- PyQt5 笔记
一.简介 pyqt5做为Python的一个模块,它有620多个类和6000个函数和方法.这是一个跨平台的工具包,它可以运行在所有主要的操作系统,包括UNIX,Windows,Mac OS.pyqt5是 ...
- pyqt5 笔记(三)py2exe 实现代码打包exe
python3.4 安装64位的版本 py2exe 下载地址: https://pypi.python.org/pypi/py2exe/0.9.2.0#downloads cmd——>进入pyf ...
- pyqt5 笔记(二)实现http请求发送
上个图~ index.py 文件 # -*- coding: utf-8 -*- from PyQt5 import QtWidgets,QtCore #从pyqt库导入QtWindget通用窗口类 ...
- PyQt5 笔记(05):信号/槽
PyQt 的很多类都内置了信号和槽.下图是 Qt 官方文档对 QThread 类中包含的信号/槽的描述: 一.信号/槽 都是内置的 请看一个最简单的程序: 按钮点击后,窗口关闭 代码: class T ...
- PyQt5 笔记(04):主窗口卡死问题
本文基于:windows 7 + python 3.4 知识点: 1. 将 time.sleep 替换为 QTimer 2. 将 time.sleep 放入到 QThread 3. 使用 QThrea ...
- PyQt5 笔记(03):弹出窗口大全
本文实现了PyQt5个各种弹出窗口:输入框.消息框.文件对话框.颜色对话框.字体对话框.自定义对话框 其中,为了实现自定义对话框的返回值,使用了信号/槽 本文基于 windows 7 + python ...
随机推荐
- POC挖矿没有前途
最好的工作量证明是能力证明,能力不适合存储.望文生义,能力的本质意义是“能”和“力”(所有的词汇都按照望文生义理解,因为所有不能望文生义的词汇都是不良的已经被前人修正或将来被后人修正)能力是流动的,迁 ...
- 基于OpenCV.Net连通域分析进行文本块分割
上一次通过投影的方式进行了文本块分割,(见 https://www.cnblogs.com/BoyTNT/p/11812323.html )但这种方法有很大的局限性,要求分行清晰.不能有字符跨多行.不 ...
- 分布式Redis深度历险-Cluster
本文为分布式Redis深度历险系列的第三篇,主要内容为Redis的Cluster,也就是Redis集群功能. Redis集群是Redis官方提供的分布式方案,整个集群通过将所有数据分成16384个槽来 ...
- python3模块
一.sys模块 import sys #print(sys.path) #打印环境变量 #print(sys.argv) print(sys.argv[3]) Sys.argv[ ]其实就是一个列表, ...
- 小鸟初学Shell编程(二)编写简单的Shell脚本
Shell脚本 编写Python.PHP脚本通常需要掌握语言的函数,那么Shell脚本则不需要,只需要掌握Linux命令就可以编写Shell脚本,因为Shell脚本就是由多个Linux命令组成,通过将 ...
- 2.原生js实现图片懒加载
网上查了很多图片懒加载的内容, 但基本上都是jQuery实现的, 没有说清楚其原理, 所以研究了一下 多的不说, 上代码, 看不明白的建议看下我的上一篇文章<1. 图解浏览器和用户设备的宽高等属 ...
- CTF必备技能丨Linux Pwn入门教程——栈溢出基础
这是一套Linux Pwn入门教程系列,作者依据i春秋Pwn入门课程中的技术分类,并结合近几年赛事中出现的一些题目和文章整理出一份相对完整的Linux Pwn教程. 课程回顾>>Linux ...
- 【设计模式】Prototype
前言 这篇讲设计模式的部分相对较少.Prototype设计模式,它提供一种复制对象的思路.使用Prototype就可以在不需要了解类结构的前提下,复制一个现有对象.写了一个代码片段,讲解使用Objec ...
- Unity导出Gradle工程给Android Studio使用
1 Unity导出Gradle项目 Unity打包时Build System选择Gradle,勾选Export Project 2 Android Studio导入Unity导出的Gradle项目 打 ...
- 章节十一、6-操作集合里面的Web元素
以下演示操作以该网站为例:https://learn.letskodeit.com/p/practice 一.如何操作多个元素(把多个元素放到集合容器中然后操作它们) 列如我们需要操作这些单选框:: ...