使用wxpython的子模块wx.lib.agw.aui 写一个记事本示例代码,运行和调试通过

传奇开心果编程
优质创作者: python技术领域
2024-09-10 10:45:56

img

传奇开心果使用IDE运行和调试通过

import wx
import wx.lib.agw.aui as aui

class NotePadFrame(wx.Frame):
    def __init__(self):
        wx.Frame.__init__(self, None, title="记事本", size=(800, 600))

        # 创建菜单栏
        menu_bar = wx.MenuBar()
        
        # 文件菜单
        file_menu = wx.Menu()
        new_item = file_menu.Append(wx.ID_NEW, "新建", "新建文件")
        open_item = file_menu.Append(wx.ID_OPEN, "打开", "打开文件")
        save_item = file_menu.Append(wx.ID_SAVE, "保存", "保存文件")
        menu_bar.Append(file_menu, "文件")

        # 编辑菜单
        edit_menu = wx.Menu()
        undo_item = edit_menu.Append(wx.ID_UNDO, "撤销", "撤销上一步操作")
        redo_item = edit_menu.Append(wx.ID_REDO, "重做", "重做上一步操作")
        edit_menu.AppendSeparator()
        cut_item = edit_menu.Append(wx.ID_CUT, "剪切", "剪切选中的文本")
        copy_item = edit_menu.Append(wx.ID_COPY, "复制", "复制选中的文本")
        paste_item = edit_menu.Append(wx.ID_PASTE, "粘贴", "粘贴文本")
        menu_bar.Append(edit_menu, "编辑")
        
        self.SetMenuBar(menu_bar)

        # 工具栏创建
        self.toolbar = self.CreateToolBar()
        self.toolbar.AddTool(wx.ID_NEW, "新建", wx.ArtProvider.GetBitmap(wx.ART_NEW, wx.ART_TOOLBAR))
        self.toolbar.AddTool(wx.ID_OPEN, "打开", wx.ArtProvider.GetBitmap(wx.ART_FILE_OPEN, wx.ART_TOOLBAR))
        self.toolbar.AddTool(wx.ID_SAVE, "保存", wx.ArtProvider.GetBitmap(wx.ART_FILE_SAVE, wx.ART_TOOLBAR))
        self.toolbar.AddSeparator()
        self.toolbar.AddTool(wx.ID_UNDO, "撤销", wx.ArtProvider.GetBitmap(wx.ART_UNDO, wx.ART_TOOLBAR))
        self.toolbar.AddTool(wx.ID_REDO, "重做", wx.ArtProvider.GetBitmap(wx.ART_REDO, wx.ART_TOOLBAR))
        self.toolbar.AddSeparator()
        self.toolbar.AddTool(wx.ID_CUT, "剪切", wx.ArtProvider.GetBitmap(wx.ART_CUT, wx.ART_TOOLBAR))
        self.toolbar.AddTool(wx.ID_COPY, "复制", wx.ArtProvider.GetBitmap(wx.ART_COPY, wx.ART_TOOLBAR))
        self.toolbar.AddTool(wx.ID_PASTE, "粘贴", wx.ArtProvider.GetBitmap(wx.ART_PASTE, wx.ART_TOOLBAR))
        self.toolbar.Realize()

        # 绑定菜单和工具栏事件
        self.Bind(wx.EVT_MENU, self.on_new, new_item)
        self.Bind(wx.EVT_MENU, self.on_open, open_item)
        self.Bind(wx.EVT_MENU, self.on_save, save_item)
        self.Bind(wx.EVT_MENU, self.on_undo, undo_item)
        self.Bind(wx.EVT_MENU, self.on_redo, redo_item)
        self.Bind(wx.EVT_MENU, self.on_cut, cut_item)
        self.Bind(wx.EVT_MENU, self.on_copy, copy_item)
        self.Bind(wx.EVT_MENU, self.on_paste, paste_item)
        
        self.Bind(wx.EVT_TOOL, self.on_new, id=wx.ID_NEW)
        self.Bind(wx.EVT_TOOL, self.on_open, id=wx.ID_OPEN)
        self.Bind(wx.EVT_TOOL, self.on_save, id=wx.ID_SAVE)
        self.Bind(wx.EVT_TOOL, self.on_undo, id=wx.ID_UNDO)
        self.Bind(wx.EVT_TOOL, self.on_redo, id=wx.ID_REDO)
        self.Bind(wx.EVT_TOOL, self.on_cut, id=wx.ID_CUT)
        self.Bind(wx.EVT_TOOL, self.on_copy, id=wx.ID_COPY)
        self.Bind(wx.EVT_TOOL, self.on_paste, id=wx.ID_PASTE)

        # 使用AUI管理器创建一个选项卡管理
        self.mgr = aui.AuiManager(self)
        self.notebook = aui.AuiNotebook(self)
        self.mgr.AddPane(self.notebook, aui.AuiPaneInfo().CenterPane().PaneBorder(False))
        self.mgr.Update()

    def on_new(self, event):
        new_tab = wx.TextCtrl(self.notebook, style=wx.TE_MULTILINE)
        self.notebook.AddPage(new_tab, "新建文件")

    def on_open(self, event):
        with wx.FileDialog(self, "打开文件", wildcard="Text files (*.txt)|*.txt",
                           style=wx.FD_OPEN | wx.FD_FILE_MUST_EXIST) as fileDialog:
            if fileDialog.ShowModal() == wx.ID_CANCEL:
                return  # 用户取消
            
            path = fileDialog.GetPath()
            try:
                with open(path, 'r', encoding='utf-8') as file:
                    content = file.read()
                    new_tab = wx.TextCtrl(self.notebook, style=wx.TE_MULTILINE)
                    new_tab.SetValue(content)
                    self.notebook.AddPage(new_tab, path.split('/')[-1])
            except IOError:
                wx.LogError(f"无法打开文件 '{path}'。")

    def on_save(self, event):
        current_page = self.notebook.GetCurrentPage()
        if current_page:
            with wx.FileDialog(self, "保存文件", wildcard="Text files (*.txt)|*.txt",
                               style=wx.FD_SAVE | wx.FD_OVERWRITE_PROMPT) as fileDialog:
                if fileDialog.ShowModal() == wx.ID_CANCEL:
                    return  # 用户取消
                
                path = fileDialog.GetPath()
                try:
                    with open(path, 'w', encoding='utf-8') as file:
                        content = current_page.GetValue()
                        file.write(content)
                except IOError:
                    wx.LogError(f"无法保存文件 '{path}'。")

    def on_undo(self, event):
        current_page = self.notebook.GetCurrentPage()
        if current_page and current_page.CanUndo():
            current_page.Undo()

    def on_redo(self, event):
        current_page = self.notebook.GetCurrentPage()
        if current_page and current_page.CanRedo():
            current_page.Redo()

    def on_cut(self, event):
        current_page = self.notebook.GetCurrentPage()
        if current_page:
            current_page.Cut()

    def on_copy(self, event):
        current_page = self.notebook.GetCurrentPage()
        if current_page:
            current_page.Copy()

    def on_paste(self, event):
        current_page = self.notebook.GetCurrentPage()
        if current_page:
            current_page.Paste()

class MyApp(wx.App):
    def OnInit(self):
        frame = NotePadFrame()
        frame.Show()
        return True

if __name__ == "__main__":
    app = MyApp()
    app.MainLoop()
...全文
581 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复
内容概要:本文围绕“阶梯碳下考虑P2G-CCS与供需灵活响应的IES优化调度”展开,基于Matlab平台构建综合能源系统(IES)在阶梯式碳交易机制下的优化调度模型。研究深度融合电制气(P2G)与碳捕集、利用与封存(CCS)技术,结合需求侧灵活响应机制,旨在提升系统的低碳运行能力与经济性。通过建立多能流耦合的优化模型,协调电力、天然气、热力等多种能源形式的协同调度,有效降低系统碳排放强度,并借助YALIMIP工具包调用求解器进行高效求解。文档提供了完整的代码实现、模型构建流程与结果分析方法,涵盖从问题建模到仿真实现的全过程,具备较强的可复现性与科研参考价值。; 适合人群:具备电力系统、能源系统或优化建模相关背景的研究生、高校教师及工程技术人员,尤其适合从事综合能源系统、碳减排策略、P2G与CCS技术集成研究的专业人员,需熟练掌握Matlab编程与基本的数学规划知识。; 使用场景及目标:①用于研究阶梯式碳交易政策下综合能源系统的低碳经济调度策略;②支撑P2G-CCS技术与需求响应机制在IES中的仿真集成与性能评估;③作为撰高水平学术论文(如EI/SCI收录)的技术基础与复现资源,推动碳中和背景下能源系统优化方向的创新研究。; 阅读建议:建议结合百度网盘提供的完整代码与资料包,按照模块逐步调试程序,重点理解目标函数的设计逻辑、碳交易成本的建模方式、约束条件的数学表达及求解器的配置方法,同时关注多能耦合设备的建模细节,配合公众号“荔枝科研社”获取持续的技术支持与案例拓展。
内容概要:本文系统研究了基于卷积神经网络(CNN)与支持向量机(SVM)融合的CNN-SVM混合模型在数据分类预测中的应用,尤其聚焦于工业故障识别领域。通过Matlab平台实现,该方法首先利用CNN强大的多层次特征提取能力对原始输入数据进行深度特征学习,自动捕获关键局部模式与空间结构信息,随后将提取的高层特征作为输入传递至SVM分类器,借助SVM在高维空间中小样本条件下卓越的分类性能与泛化能力完成最终判别任务。文中详尽阐述了模型的整体架构设计、网络参数配置、训练优化流程及特征迁移机制,充分结合了深度学习在特征表达上的优势与传统机器学习在分类决策上的稳健性。实验部分通过实际故障数据集验证了该混合模型相较于单一CNN或SVM模型在分类准确率、鲁棒性和抗过拟合能力方面的显著提升,证明了其在复杂故障诊断任务中的有效性与先进性; 适合人群:具备一定机器学习与深度学习理论基础,熟悉Matlab编程环境,从事故障诊断、模式识别、智能制造、电力系统监控或工业数据分析等相关领域的研究生、科研人员及工程技术开发者; 使用场景及目标:① 应用于旋转机械、电力设备、航空航天等领域的多类别故障识别与状态监测;② 掌握深度特征提取与传统分类器融合的技术路径,提升小样本、高噪声环境下数据分类的精度与可靠性;③ 为撰高水平学术论文、开展科研项目或工程实践提供可复现的算法框架与完整代码支持; 阅读建议:读者应深入理解CNN与SVM的协同工作机制,重点分析特征提取层与分类层之间的接口设计,建议动手运行调试所提供的Matlab代码,尝试在不同数据集上进行迁移实验与参数调优,以全面掌握该混合模型的应用技巧与优化策略。

8

社区成员

发帖
与我相关
我的任务
社区描述
软件开发那些事
软件工程需求分析团队开发 个人社区 甘肃省·酒泉市
社区管理员
  • 传奇开心果编程
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧