Pyinstaller не может найти libvlc.dll

Во-первых, я знаю, что подобные вопросы задавались, но я не смог найти решение своей проблемы. Спасибо за любую помощь!

Я пытался создать исполняемый файл с помощью pyinstaller, и у меня возникли проблемы с тем, чтобы pyinstaller нашел .dll для libvlc. В частности: libvlc.dll и libvlccore.dll. Они находятся в моем каталоге VideoLAN\VLC, но я также скопировал все dll из моего каталога VideoLAN\VLC в мой каталог Compile рядом с моими файлами test.py и test.spec. Я также добавил свой каталог VideoLAN\VLC в свои переменные среды, чтобы помочь pyinstaller найти их. Несмотря на это, когда я запускаю pyinstaller test.spec, я получаю это предупреждение:

48352 WARNING: lib not found: libvlccore.dll dependency of C:\Users\chipc\Desktop\Code\Python\KivyTest\KivyTut\Compile\libvlc.dll

Остальную часть журнала компиляции можно увидеть здесь: https://pastebin.com/DJmkQ7nm

При попытке запустить сгенерированный test.exe выдает следующее:

Traceback (most recent call last):
File "site-packages\PyInstaller\loader\pyiboot01_bootstrap.py", line 149, in __init__
File "ctypes\__init__.py", line 356, in __init__
OSError: [WinError 193] %1 is not a valid Win32 application

During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "test.py", line 18, in <module>
File "<frozen importlib._bootstrap>", line 983, in _find_and_load
File "<frozen importlib._bootstrap>", line 967, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 677, in _load_unlocked
File "c:\users\chipc\appdata\local\programs\python\python37-32\lib\site-packages\PyInstaller\loader\pyimod03_importers.py", line 627, in exec_module
exec(bytecode, module.__dict__)
File "site-packages\vlc.py", line 207, in <module>
File "site-packages\vlc.py", line 163, in find_lib
File "site-packages\PyInstaller\loader\pyiboot01_bootstrap.py", line 151, in __init__
__main__.PyInstallerImportError: Failed to load dynlib/dll 'C:\\Users\\chipc\\Desktop\\Code\\Python\\KivyTest\\KivyTut\\Compile\\dist\\test\\libvlc.dll'. Most probably this dynlib/dll was not found when the application was frozen.
[16044] Failed to execute script test

Кроме того, сгенерированная папка, содержащая test.exe, содержит внутри себя libvlc.dll.

Вот мой файл test.spec:

# -*- mode: python ; coding: utf-8 -*-
from kivy_deps import sdl2, glew
block_cipher = None


a = Analysis(['test.py'],
             pathex=[('C:\\Users\\chipc\\Desktop\\Code\\Python\\KivyTest\\KivyTut\\Compile'), ('C:\Program Files\VideoLAN\VLC')],
             binaries=[('./libvlc.dll', '.'), ('./axvlc.dll', '.'), ('./libvlccore.dll', '.'), ('./npvlc.dll', '.')],
             datas=[],
             hiddenimports=[],
             hookspath=[],
             runtime_hooks=[],
             excludes=[],
             win_no_prefer_redirects=False,
             win_private_assemblies=False,
             cipher=block_cipher,
             noarchive=False)
a.datas += Tree('C:\\Program Files\\VideoLAN\\VLC\\plugins', prefix='plugins')
pyz = PYZ(a.pure, a.zipped_data,
             cipher=block_cipher)
exe = EXE(pyz,
          a.scripts,
          [],
          exclude_binaries=True,
          name='test',
          debug=False,
          bootloader_ignore_signals=False,
          strip=False,
          upx=True,
          console=True )
coll = COLLECT(exe, Tree('C:\\Users\\chipc\\AppData\\Local\\Programs\\Python\\Python37-32\\Lib\\site-packages\\kivy_deps'),
               a.binaries,
               a.zipfiles,
               a.datas,
               *[Tree(p) for p in (sdl2.dep_bins + glew.dep_bins)],
               strip=False,
               upx=True,
               name='test')

Программа работает в PyCharm. Как я могу заставить pyinstaller найти libvlc.dll?

На всякий случай, вот как выглядит мой каталог Compile:

axvlc.dll
libvlc.dll
libvlccore.dll
npvlc.dll
test.py
test.spec

Спасибо за любую помощь, уже пару дней пытаюсь разобраться!


person Aviolin    schedule 24.08.2019    source источник
comment
Возможно, это поможет.   -  person Masoud Rahimi    schedule 25.08.2019
comment
Спасибо за ответ! Я уже видел этот пост и попытался использовать формулу .spec, размещенную там, в очень маленьком скрипте, который просто импортирует vlc и время и печатает что-то каждые 3 секунды. Я все еще получаю аналогичную ошибку: __main__.PyInstallerImportError: Failed to load dynlib/dll 'C:\\Users\\chipc\\AppData\\Local\\Temp\\_MEI173322\\libvlc.dll'. Most probably this dynlib/dll was not found when the application was frozen.   -  person Aviolin    schedule 25.08.2019
comment
Эта ошибка означает, что он не может найти libvlc.dll. Во время выполнения откройте каталог _MEIXXXX и проверьте, есть ли файл там или нет.   -  person Masoud Rahimi    schedule 25.08.2019
comment
Похоже, он создает libVLC.dll в каталоге _MEIXXXX во время выполнения. Перед сбоем каталог выглядит так: _bz2 _ctypes _hashlib _lzma _socket _ssl libcrypto-1_1.dll libssl-1_1.dll libVLC.dll libvlc.dylib libvlccore.dylib VCRUNTIME140.dll   -  person Aviolin    schedule 25.08.2019
comment
Это странно, потому что у вас есть библиотеки DLL в каталоге. Вы пытались запустить свой скрипт напрямую?   -  person Masoud Rahimi    schedule 25.08.2019
comment
Да, запуск python test.py работает правильно. Кроме того, мне кажется странным, что я получаю предупреждение о том, что libvlc.dll имеет зависимость (libvlccore.dll) во время компиляции - так что она нашла ее во время компиляции - но затем не будет смог найти libvlc.dll при запуске exe...   -  person Aviolin    schedule 25.08.2019