# -*- mode: python ; coding: utf-8 -*- import os from PyInstaller.utils.hooks import collect_all, copy_metadata import docutranslate # 初始化列表 datas = [] binaries = [] hiddenimports = ['markdown.extensions.tables', 'pymdownx.arithmatex', 'pymdownx.superfences', 'pymdownx.highlight', 'pygments', 'docling_ibm_models', 'docling_parse','cv2'] # 先收集第三方包的资源 for package in ['easyocr', 'docling', 'pygments', 'docling_ibm_models']: try: tmp_ret = collect_all(package) datas += tmp_ret[0] binaries += tmp_ret[1] hiddenimports += tmp_ret[2] except Exception as e: print(f"Warning: Failed to collect resources for {package}: {e}") try: datas += copy_metadata('docling-ibm-models') # 这里必须用连字符(pip名) datas += copy_metadata('docling-parse') # 预防性添加 except Exception as e: print(f"Warning: Failed to copy metadata: {e}") # 然后添加您的自定义资源(避免重复) custom_datas = [ ('./.venv/Lib/site-packages/docling_parse/pdf_resources_v2', 'docling_parse/pdf_resources_v2'), ('./docutranslate/static', 'docutranslate/static'), ('./docutranslate/template', 'docutranslate/template') ] # 避免添加重复的数据 for data in custom_datas: if data not in datas: datas.append(data) a = Analysis( ['docutranslate/app.py'], # 使用正斜杠 pathex=[], # 添加当前工作目录到 pathex binaries=binaries, datas=datas, hiddenimports=list(set(hiddenimports)), # 去重 hookspath=[], hooksconfig={}, runtime_hooks=[], excludes=[], noarchive=False, optimize=0, ) pyz = PYZ(a.pure) exe = EXE( pyz, a.scripts, a.binaries, a.datas, [], name=f'DocuTranslate_full-{docutranslate.__version__}-win', debug=False, bootloader_ignore_signals=False, strip=False, upx=True, upx_exclude=[], runtime_tmpdir=None, console=True, disable_windowed_traceback=False, argv_emulation=False, target_arch=None, codesign_identity=None, entitlements_file=None, icon='DocuTranslate.ico', )