Electron+Vue+pyinstaller服务打包

electron环境安装略

1. electron的入口文件配置test.js, 需要在package.json 配置文件中指定main: src/test.js

const { app, BrowserWindow } = require('electron')const createWindow = () => {const win = new BrowserWindow({width: 800,height: 600})// win.loadFile('index.html')// 下面的url为自己启动vite项目的url。// win.loadURL('http://127.0.0.1:28087/')// 在窗口内要展示的内容为 ./dist/index.html,即打包生成的index.html// mainWindow.loadURL(url.format({//   pathname: path.join(__dirname, './dist', 'index.html'),//   protocol: 'file:',//   slashes: true// }));win.loadFile('./dist/index.html')// 自动打开调试台mainWindow.webContents.openDevTools({detach: true});}app.whenReady().then(() => {createWindow()app.on('activate', () => {if (BrowserWindow.getAllWindows().length === 0) createWindow()})
})app.on('window-all-closed', () => {if (process.platform !== 'darwin') {app.quit()}
})

2. vue文件单独打包,命令: npm run build,  test.js文件在src下, 然后将vue打包的dist文件,需要手动拷贝到src下

3. 打包electron  命令:  electron-builder

关于python服务打包运行, 不需要部署python环境的方式

1.安装依赖, pip install pyinstaller

2.打包服务pyinstaller yourscript.py

具体参见 https://blog.csdn.net/weixin_40025666/article/details/131191945

将py打包程序嵌入到electron启动脚本中, 并将py打包的应用包依赖包复制到/app下

app.on('ready', async () => {// 启动服务器exetry{ cmd.run(`./app/app.exe`,function(err, data, stderr){console.log(data)console.log(err)console.log(stderr)});}catch(e){console.log(e)}createWindow()
})

其中cmd.run命令需要node安装

npm install node-cmd --save

并在js中引入 const cmd = require('node-cmd');


1. js本地调试, 运行node js文件即可

2. 除了node_cmd, 还可以使用组件chile_process调用exe

var child_process = require('child_process');
child_process.exec(`start cmd.exe /K ping 127.0.0.1`);

3.eletron需要打包带进去的文件, 以及文件路径

​
var child_process = require('child_process');
child_process.exec(`start cmd.exe /K ping 127.0.0.1`);​

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

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

相关文章

实体类和对象之间的关系是什么

实体类(Entity Class)和对象(Object)在面向对象编程(OOP, Object-Oriented Programming)和ORM(Object-Relational Mapping)框架如Hibernate中扮演着重要的角色。以下是它们之间的关系…

守好参数之门:防止 IllegalArgumentException 入侵的七大策略

1. 原因分析 java.lang.IllegalArgumentException 是 Java 中的一个运行时异常,它通常表示向方法传递了一个不合法或不适当的参数。这种异常不会由 Java 虚拟机自动抛出,而是由程序员在编写代码时通过显式地调用 throw 语句来抛出,或者在某些…

如何利用python选股

使用Python进行选股是一个复杂但有趣的过程,它结合了数据分析、统计建模和机器学习等多个领域的知识。 由于篇幅限制,我将提供一个概述性的框架和关键步骤,并尽量保持内容的精炼和深入。 一、引言 背景介绍:简述股市投资的重要性和复杂性,以及利用Python进行量化选股的优…

红龙工业设备制造有限公司亮相2024杭州数字物流技术设备展

参展企业介绍 温州红龙工业设备制造有限公司成立于2015年11月。是中国先进的工业皮带设备研发制造和工业皮带整体解决方案运营服务商,现主营皮带接头机、皮带热压机、皮带接驳机、皮带打齿机、输送带打齿机、输送带分层级、输送带导条机、输送带裁切机、高频机等工业…

力扣HOT100 - 84. 柱状图中最大的矩形

解题思路&#xff1a; 单调栈 对于一个高度height[ i ]&#xff0c;找左右两边均严格小于它的值。 class Solution {public int largestRectangleArea(int[] heights) {int n heights.length;int[] left new int[n];int[] right new int[n];Deque<Integer> mono_st…

HDFS集群间互访配置

HDFS集群间互访配置 目录 1 HDFS互访 1.1 前置条件 1.2 互访配置 2 NameService修改 HDFS互访

【element-plus】自动导入 + typescript 提示

1、自动导入 2、引用加载组件类型提示 第一步&#xff1a;安装自动导入功能所需的插件 npm install -D unplugin-vue-components unplugin-auto-import 第二步&#xff1a; vite版&#xff1a; // vite.config.ts import { defineConfig } from vite import AutoImport fr…

力扣:738. 单调递增的数字

738. 单调递增的数字 当且仅当每个相邻位数上的数字 x 和 y 满足 x < y 时&#xff0c;我们称这个整数是单调递增的。 给定一个整数 n &#xff0c;返回 小于或等于 n 的最大数字&#xff0c;且数字呈 单调递增 。 示例 1: 输入: n 10 输出: 9示例 2: 输入: n 1234 输…

【无标题】C++ 读写文件 不同方法总结

在C中&#xff0c;有多种方法可以进行文件的读写操作。下面是一些常用的方法&#xff1a; 使用iostream库进行文件读写&#xff1a; 使用ifstream类进行文件读取操作&#xff0c;可以使用open()函数打开文件&#xff0c;然后使用>>运算符或getline()函数读取文件内容。例…

linux安装配置Docker保姆级教程

Docker到底是什么? Docker 是一个开源的应用容器引擎&#xff0c;让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中&#xff0c;然后发布到任何流行的 Linux或Windows操作系统的机器上&#xff0c;也可以实现虚拟化。 容器是完全使用沙箱机制&#xff0c;相互之间…

Fastchat + vllm + ray + Qwen1.5-7b 在2080ti 双卡上 实现多卡推理加速

首先先搞清各主要组件的名称与作用: FastChat FastChat框架是一个训练、部署和评估大模型的开源平台&#xff0c;其核心特点是&#xff1a; 提供SOTA模型的训练和评估代码 提供分布式多模型部署框架 WebUI OpenAI API Controller管理分布式模型实例 Model Worker是大模型服务…

智慧仓储可视化大屏,以最直观的形式展示海量数据。

智慧仓储可视化大屏是一种通过数据可视化技术&#xff0c;将仓储管理系统中的海量数据以图表、地图、仪表盘等形式直观展示在大屏上的解决方案。它可以帮助仓储管理人员更清晰地了解仓库的运营情况&#xff0c;从而做出更明智的决策。 智慧仓储可视化大屏通常包括以下功能和特点…

三层架构慎用跨层公用数据类型

在三层架构中&#xff0c;定义公共数据类型供三个层共用是可能的&#xff0c;但这种做法需要谨慎考虑。虽然共享数据类型可以减少代码冗余和提高数据一致性&#xff0c;但也可能导致层与层之间的耦合度增加&#xff0c;从而降低了系统的可维护性和可扩展性。 如果你决定定义公…

IP 地址追踪工具促进有效的 IP 管理

网络 IP 地址空间的结构、扫描和管理方式因组织的规模和网络需求而异&#xff0c;网络越大&#xff0c;需要管理的 IP 就越多&#xff0c;IP 地址层次结构就越复杂。因此&#xff0c;如果没有 IP 地址管理&#xff08;IPAM&#xff09;解决方案&#xff0c;IP 资源过度使用和地…

cocos creator 帧率60 不生效meta50 能刷新到90

环境&#xff1a; cocos creator 2.4.3 华为meta 50 背景&#xff1a; 小游戏 需要在update 里取帧率 发现跟时间对不上 游戏设置60帧 手机上显示 90帧 cc.game.setFrameRate(30) 显示 30帧 cc.game.setFrameRate(60) 显示 90帧 结论&#xff1a; 对于老版本的cocos creator …

2024-05-10 Ubuntu上面使用libyuv,用于转换、缩放、旋转和其他操作YUV图像数据,测试实例使用I420ToRGB24

一、简介&#xff1a;libyuv 最初是由Google开发的&#xff0c;主要是为了支持WebRTC项目中的视频处理需求。用于处理YUV格式图像数据的开源库。它提供了一系列的函数&#xff0c;用于转换、缩放、旋转和其他操作YUV图像数据。 二、执行下面的命令下载和安装libyuv。 git clo…

java连锁美业收银系统源码-发布产品时选择【销售模式】是什么意思?

博弈美业管理系统源码 连锁多门店美业收银系统源码 多门店管理 / 会员管理 / 预约管理 / 排班管理 / 商品管理 / 促销活动 PC管理后台、手机APP、iPad APP、 发布总部实物商品或门店实物商品时&#xff0c;分“代销”和“买断”两种销售模式。&#xff08;参数名&#xff1a…

一探究竟:Java NIO的奥秘与原理解析

引言 在计算机编程领域&#xff0c;I/O&#xff08;输入/输出&#xff09;操作一直是至关重要的一环。在传统的IO模型中&#xff0c;通常采用阻塞IO&#xff08;Blocking I/O&#xff09;方式&#xff0c;即程序在执行IO操作时会被阻塞&#xff0c;直到IO完成才能继续执行后续…

多功能投票小程序基于ThinkPHP+FastAdmin+Uniapp(源码搭建/上线/运营/售后/维护更新)

基于ThinkPHPFastAdminUniapp开发的多功能系统&#xff0c;支持图文投票、自定义选手报名内容、自定义主题色、礼物功能(高级授权)、弹幕功能(高级授权)、会员发布、支持数据库私有化部署&#xff0c;Uniapp提供全部无加密源码。 功能特性