当前位置: 首页 > news >正文

使用python编写工具:快速生成chrome插件相关文件结构

本文将详细分析一段用 wxPython 编写的 Python 应用程序代码。该程序允许用户创建一些特定文件并将它们保存在指定的文件夹中,同时也能够启动 Google Chrome 浏览器并打开扩展页面,自动执行一些操作。
C:\pythoncode\new\crxiterationtaburl.py

全部代码

import wx
import os
import json
import subprocess
import time
import pyautogui
import pyperclipclass MyApp(wx.App):def OnInit(self):self.frame = MyFrame()self.frame.Show()return Trueclass MyFrame(wx.Frame):def __init__(self):super().__init__(parent=None, title='File Creator', size=(850, 1600))panel = wx.Panel(self)# 创建四个文本框self.memo1 = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_PROCESS_ENTER, size=(300, 250))self.memo2 = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_PROCESS_ENTER, size=(300, 250))self.memo3 = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_PROCESS_ENTER, size=(300, 250))self.memo4 = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_PROCESS_ENTER, size=(300, 250))# Add labels with file nameslabel1 = wx.StaticText(panel, label='manifest.json:')label2 = wx.StaticText(panel, label='background.js:')label3 = wx.StaticText(panel, label='popup.html:')label4 = wx.StaticText(panel, label='popup.js:')# 创建按钮self.create_button = wx.Button(panel, label='创建')self.open_button = wx.Button(panel, label='打开')# 布局# Layoutvbox = wx.BoxSizer(wx.VERTICAL)vbox.Add(label1, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.memo1, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(label2, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.memo2, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(label3, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.memo3, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(label4, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.memo4, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.create_button, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.open_button, flag=wx.EXPAND | wx.ALL, border=10)panel.SetSizer(vbox)# 绑定事件self.create_button.Bind(wx.EVT_BUTTON, self.on_create)self.open_button.Bind(wx.EVT_BUTTON, self.on_open)self.target_folder = ''# 文件夹选择对话框with wx.DirDialog(self, "选择目标文件夹") as dlg:if dlg.ShowModal() == wx.ID_OK:self.target_folder = dlg.GetPath()def on_create(self, event):if not self.target_folder:wx.MessageBox("请先选择目标文件夹", "错误", wx.OK | wx.ICON_ERROR)return# 创建images文件夹images_folder = os.path.join(self.target_folder, "images")os.makedirs(images_folder, exist_ok=True)# 保存内容到文件with open(os.path.join(images_folder, "manifest.json"), 'w') as f:json.dump(self.memo1.GetValue(), f)with open(os.path.join(images_folder, "background.js"), 'w') as f:f.write(self.memo2.GetValue())with open(os.path.join(images_folder, "popup.html"), 'w') as f:f.write(self.memo3.GetValue())with open(os.path.join(images_folder, "popup.js"), 'w') as f:f.write(self.memo4.GetValue())wx.MessageBox("文件已保存", "成功", wx.OK | wx.ICON_INFORMATION)def on_open(self, event):url = "chrome://extensions/"# Copy the URL to the clipboardpyperclip.copy(url)chrome_path = "C:/Program Files/Google/Chrome/Application/chrome.exe"  # 请根据实际路径修改subprocess.Popen([chrome_path, "chrome://extensions/"])        time.sleep(2)  # 等待Chrome启动# 发送Ctrl+Shift+Ipyautogui.hotkey('ctrl', 'shift', 'i')if __name__ == '__main__':app = MyApp()app.MainLoop()
1. 程序结构概述

这段代码定义了一个 MyApp 类作为 wxPython 应用的入口,继承自 wx.App 类。MyFrame 类继承自 wx.Frame 类,用于创建界面。程序包括文本框、按钮、文件夹选择功能以及一些自动化操作。我们一一进行详细分析。

2. 导入所需模块
import wx
import os
import json
import subprocess
import time
import pyautogui
import pyperclip
  • wx:wxPython 是一个常用于创建图形用户界面(GUI)的库,本代码利用它创建应用程序窗口、按钮、文本框等控件。
  • os:用于与操作系统交互,如创建文件夹和路径操作。
  • json:用于读写 JSON 格式的文件。
  • subprocess:用于启动外部应用程序,这里用来启动 Chrome 浏览器。
  • time:用于延时操作。
  • pyautogui:一个自动化工具库,模拟键盘和鼠标事件,这里用来模拟快捷键操作。
  • pyperclip:用于剪贴板操作,本代码用来复制 Chrome 扩展页面 URL。
3. 创建应用程序框架
class MyApp(wx.App):def OnInit(self):self.frame = MyFrame()self.frame.Show()return True
  • MyApp 类继承自 wx.App,是整个应用程序的核心类。
  • OnInit 方法在应用初始化时被调用,创建并显示 MyFrame 窗口。
4. 创建主窗口 MyFrame
class MyFrame(wx.Frame):def __init__(self):super().__init__(parent=None, title='File Creator', size=(850, 1600))panel = wx.Panel(self)
  • MyFrame 类继承自 wx.Frame,代表了应用程序的主窗口。
  • super().__init__(parent=None, title='File Creator', size=(850, 1600)):初始化父类 wx.Frame,并设置窗口的标题和大小。
  • panel = wx.Panel(self):在窗口内添加一个面板,用来包含其他控件。
5. 添加控件
        self.memo1 = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_PROCESS_ENTER, size=(300, 250))self.memo2 = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_PROCESS_ENTER, size=(300, 250))self.memo3 = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_PROCESS_ENTER, size=(300, 250))self.memo4 = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_PROCESS_ENTER, size=(300, 250))
  • 这四个 TextCtrl 控件分别用于输入四种类型的文本内容(JSON、JS、HTML)。
  • wx.TE_MULTILINE 使得文本框支持多行文本,wx.TE_PROCESS_ENTER 使得用户可以按 Enter 键处理输入。
        label1 = wx.StaticText(panel, label='manifest.json:')label2 = wx.StaticText(panel, label='background.js:')label3 = wx.StaticText(panel, label='popup.html:')label4 = wx.StaticText(panel, label='popup.js:')
  • 这些标签控件用于标识每个文本框的内容。
        self.create_button = wx.Button(panel, label='创建')self.open_button = wx.Button(panel, label='打开')
  • create_button 按钮用于创建文件,open_button 按钮用于打开 Chrome 扩展页面。
6. 布局管理
        vbox = wx.BoxSizer(wx.VERTICAL)vbox.Add(label1, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.memo1, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(label2, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.memo2, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(label3, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.memo3, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(label4, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.memo4, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.create_button, flag=wx.EXPAND | wx.ALL, border=10)vbox.Add(self.open_button, flag=wx.EXPAND | wx.ALL, border=10)
  • 使用 wx.BoxSizer 来管理布局,vbox 采用垂直排列方式(wx.VERTICAL)。
  • 每个控件之间加入适当的间距(border=10)。
7. 文件夹选择对话框
        self.target_folder = ''with wx.DirDialog(self, "选择目标文件夹") as dlg:if dlg.ShowModal() == wx.ID_OK:self.target_folder = dlg.GetPath()
  • 通过 wx.DirDialog 弹出文件夹选择对话框,允许用户选择一个目标文件夹。选择后的路径保存在 self.target_folder 中。
8. 文件创建操作
    def on_create(self, event):if not self.target_folder:wx.MessageBox("请先选择目标文件夹", "错误", wx.OK | wx.ICON_ERROR)return
  • on_create 方法会在用户点击“创建”按钮时被触发。首先检查是否选择了目标文件夹。
        images_folder = os.path.join(self.target_folder, "images")os.makedirs(images_folder, exist_ok=True)
  • 在目标文件夹下创建 images 文件夹(如果不存在的话)。
        with open(os.path.join(images_folder, "manifest.json"), 'w') as f:json.dump(self.memo1.GetValue(), f)with open(os.path.join(images_folder, "background.js"), 'w') as f:f.write(self.memo2.GetValue())with open(os.path.join(images_folder, "popup.html"), 'w') as f:f.write(self.memo3.GetValue())with open(os.path.join(images_folder, "popup.js"), 'w') as f:f.write(self.memo4.GetValue())
  • 将文本框中的内容保存为相应文件,分别保存为 manifest.jsonbackground.jspopup.htmlpopup.js
        wx.MessageBox("文件已保存", "成功", wx.OK | wx.ICON_INFORMATION)
  • 保存成功后弹出提示框。
9. 打开扩展页面并自动执行操作
    def on_open(self, event):url = "chrome://extensions/"pyperclip.copy(url)chrome_path = "C:/Program Files/Google/Chrome/Application/chrome.exe"subprocess.Popen([chrome_path, "chrome://extensions/"])        time.sleep(2)pyautogui.hotkey('ctrl', 'shift', 'i')
  • on_open 方法中,程序将打开 Chrome 浏览器的扩展页面,并模拟快捷键 Ctrl+Shift+I 打开开发者工具。这些操作通过 pyperclip(复制 URL)、subprocess(启动 Chrome)、pyautogui(模拟快捷键)完成。

运行结果

在这里插入图片描述

10. 总结

这段代码展示了如何使用 wxPython 创建一个简单的应用程序,完成以下功能:

  1. 创建指定格式的文件(如 manifest.jsonbackground.js)。
  2. 启动 Chrome 浏览器并打开扩展页面。
  3. 通过模拟键盘操作,自动化执行一些开发者工具的操作。

此应用程序展示了如何将文件操作、UI 设计和自动化脚本结合起来,构建一个具有实用功能的工具。如果你正在开发类似的应用程序,这段代码为你提供了一个很好的起点。


http://www.mrgr.cn/news/75441.html

相关文章:

  • Github Copilot学习笔记
  • vue3+ts+element-plus 输入框el-input设置背景颜色
  • 2008-2019年各省城镇人口数据
  • 卷积神经02-CUDA+Pytorch环境安装
  • 并行服务、远程SSH无法下载conda,报错404
  • 制造企业“数字化转型”典型场景参考
  • JAVA学习-练习试用Java实现“网络编程”
  • 【大数据技术基础 | 实验十一】Hive实验:新建Hive表
  • 性能调优专题(9)之从JDK源码级别解析JVM类加载机制
  • 【汇编语言】包含多个段的程序(一)—— 在代码段中使用数据和栈
  • 无需魔法的AI绘图神器,不能错过的宝藏软件!
  • Android 无签名系统 debug 版本APK push到设备引起的开机异常问题分析(zygote进程)
  • 双十二有什么好物推荐?盘点2024年双十二最值得入手的好物!
  • P3372 【模板】线段树 1
  • 大模型重塑软件研发,从辅助编程到多 Agent 协同还有多远?
  • WSADATA 关键字详细介绍
  • 用EXCEL一列数据拼接SQL的where条件in语句
  • 使用Python实现智能食品储存管理的深度学习模型
  • 快速上手 Hugging Face Transformers:完整模型微调训练步骤全攻略
  • 历久弥新的c-Met:靶向疗法研究进展
  • 【route】route add命令详解
  • 去中心化应用(DApps)在Web3生态中的发展趋势
  • 大模型时代,呼叫中心的呼入机器人系统如何建设?
  • 【Visual Studio】使用VS调试(Debug)
  • APEX高性能减速机MG/MGH系列 高负载应用下的精准动力传输
  • 2024年11月14日