electron-vite 配合python

要实现的功能

  1. pdf转化和doc
  2. doc转换为pdf
  3. pdf的合并

Q:为什么不直接使用node?

复制代码
 只想尝试electron是否能和其他的程序相互配合
  1. 构建工具 yarn | npm 不要选择pnpm
  2. electron框架选择 electron-vite
  3. 转换功能选择 python库
bash 复制代码
  from pdf2docx import Converter
  import docx2pdf
  from PyPDF2 import  PdfMerger

electron-vite要怎么嵌入python

可看csdn这篇文章

项目结构


所有的python代码都要放到resources文件夹下面

注意点1

js 复制代码
import pdf2docPathAddress from '../../resources/pythonCode/pdf2doc.py?asset'
import pythonPathAddress from '../../resources/python/python-3.13.5-embed-amd64/python.exe?asset'
import pdfMergePathAddress from '../../resources/pythonCode/PdfFileMerger.py?asset'
复制代码
上述代码导入的时候一定要写?asset,让electron-vite知道这是静态文件,
否则打包的时候会将python代码位置放错

注意点2

js 复制代码
const scriptPath = is.dev
  ? pdf2docPathAddress
  : pdf2docPathAddress.replace('app.asar', 'app.asar.unpacked')

const pythonPath = is.dev
  ? pythonPathAddress
  : pythonPathAddress.replace('app.asar', 'app.asar.unpacked')

const pdfMergePath = is.dev
  ? pdfMergePathAddress
  : pdfMergePathAddress.replace('app.asar', 'app.asar.unpacked')
复制代码
 必须这么做,打包之后静态文件,也就是python代码会在app.asar.unpacked文件下面! 
 如果不更改那么在使用spawn的时候,不能找到python.exe

为什么静态文件会放到resources下面?

yml 复制代码
asarUnpack:
  - resources/**
因为electron-builder.yml中配置,你可自己手动更改,但不建议

贴出所有pdf转换为doc代码剩余都类似

js 复制代码
ipcMain.handle('convert-pdf-to-docx', async (_, pdfPath) => {
  const docxPath = pdfPath.replace(/\.pdf$/, '.docx')
  return new Promise((resolve, reject) => {
    const py = spawn(pythonPath, [scriptPath, pdfPath, docxPath, 'convert-pdf-to-docx'])
    py.on('close', (code) => {
      if (code === 0) {
        resolve(docxPath)
        // 系统弹窗
        dialog
          .showMessageBox({
            type: 'info',
            title: '转换成功',
            message: '文件已成功转换为 DOCX 格式'
          })
          .then(() => {
            // 打开文件所在目录
            shell.showItemInFolder(docxPath)
            // 打开文件
            shell.openPath(docxPath)
          })
      } else {
        // 系统弹窗
        dialog
          .showMessageBox({
            type: 'error',
            title: '转换失败',
            message: `转换失败,退出码: ${code}`
          })
          .then(() => {
            reject(new Error(`转换失败,退出码: ${code}`))
          })
      }
    })

    py.on('error', (error) => {
      reject(new Error(`启动 Python 失败: ${error.message}`))
    })
  })
})
python 复制代码
import sys
import os

# pdf和world相互转换

# 自动注入嵌入式 python site-packages 路径
def inject_site_packages():
  base_dir = os.path.dirname(os.path.abspath(__file__))
  # 适配你的嵌入式目录结构(根据实际路径调整)
  python_lib = os.path.abspath(os.path.join(base_dir, '..', 'python', 'python-3.13.5-embed-amd64', 'Lib', 'site-packages'))
  if python_lib not in sys.path:
    sys.path.insert(0, python_lib)
inject_site_packages()

from pdf2docx import Converter
import docx2pdf
from pathlib import Path

def pdf_to_docx(pdf: Path, docx: Path):
  try:
    cv = Converter(str(pdf))
    cv.convert(str(docx), start=0, end=None)
    cv.close()
    print(f"文件 {pdf} 已成功转换为 {docx}")
    return True
  except Exception as e:
    print(f"转换过程中出错: {e}")
    raise

def docx_to_pdf(docx: Path, pdf: Path):
    try:
        # 确保目标目录存在
        out_dir = pdf.parent
        out_dir.mkdir(parents=True, exist_ok=True)
        docx2pdf.convert(str(docx), str(pdf))
        print(f"文件 {docx} 已成功转换为 {pdf}")
        return True
    except Exception as e:
        print(f"docx 转 pdf 过程中出错: {e}")
        return False

if __name__ == '__main__':
  pdf_path = sys.argv[1]
  docx_path = sys.argv[2]
  action = sys.argv[3]
  if action == 'convert-pdf-to-docx':
    pdf = Path(pdf_path)
    docx = Path(docx_path)
    pdf_to_docx(pdf, docx)
  elif action == 'convert-docx-to-pdf':
    docx = Path(docx_path)
    pdf = Path(pdf_path)
    docx_to_pdf(docx, pdf)

页面展示



相关推荐
User_芊芊君子几秒前
CANN010:PyASC Python编程接口—简化AI算子开发的Python框架
开发语言·人工智能·python
白日做梦Q11 分钟前
Anchor-free检测器全解析:CenterNet vs FCOS
python·深度学习·神经网络·目标检测·机器学习
喵手25 分钟前
Python爬虫实战:公共自行车站点智能采集系统 - 从零构建生产级爬虫的完整实战(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集公共自行车站点·公共自行车站点智能采集系统·采集公共自行车站点导出csv
喵手33 分钟前
Python爬虫实战:地图 POI + 行政区反查实战 - 商圈热力数据准备完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·地区poi·行政区反查·商圈热力数据采集
xjt_090136 分钟前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
熊猫_豆豆38 分钟前
YOLOP车道检测
人工智能·python·算法
nimadan1239 分钟前
**热门短剧小说扫榜工具2025推荐,精准捕捉爆款趋势与流量
人工智能·python
默默前行的虫虫44 分钟前
MQTT.fx实际操作
python
我是伪码农1 小时前
Vue 2.3
前端·javascript·vue.js
YMWM_1 小时前
python3继承使用
开发语言·python