Я пытаюсь преобразовать свой скрипт Python, содержащий модуль pdftotext, в автономный .exe. Когда я тестирую приложение .exe в своей среде anaconda, оно работает правильно, но когда я тестирую его на другом устройстве, оно дает мне эту ошибку:
File "main.py", line 3, in <module> #line 3 is import pdftotext
"ImportError: DLL load failed: The specified module could not be found"
[7300] Failed to execute script main
Я уверен, что проблема связана с модулем pdftotext, потому что я попробовал простой скрипт ниже и работает правильно:
a=input("Start")
print("Hello world")
b=input("End")
Ошибка появляется, если я конвертирую этот скрипт:
import pdftotext
a=input("Inserisci")
print("Hello world")
b=input("Fine")
Извините за мой плохой английский, я из Италии. надеюсь понятно выразился спасибо всем
РЕДАКТИРОВАТЬ 1. Я понял, что проблема может быть связана с poppler (библиотека, используемая pdftotext), но на данный момент я не могу понять, какой файл подключается для импорта poppler.
РЕДАКТИРОВАТЬ 2. После некоторой работы я обнаружил две вещи, которые могут помочь лучше понять мою ситуацию:
Приложение .exe работает на моем устройстве (даже за пределами среды anaconda, где я установил poppler и pdftotext), но не работает на других устройствах (я пробовал два разных ноутбука с Windows, и ошибка та же); скрипт без 'pdftotext' работает на всех устройствах
В папке dist (сборка с помощью pyinstaller) появляется один файл с именем pdftotext: это файл «pdftotext.cp37-win_amd64.pyd» (я не уверен, что это такое). В моей среде anaconda есть только два файла, которые содержат строку «pdftotext»: это файлы «pdftotext.cp37-win_amd64.pyd» и «pdftotext.exe».
РЕДАКТИРОВАТЬ 3 Полная ошибка при запуске main.exe на другом устройстве:
Traceback (most recent call last):
File "main.py",line 1, in <module>
ImportError: DLL load failed: The specified module could not be found
[7140] Failed to execute script main
Полный журнал pyinstaller:
(envPDF) C:\Users\miche\Desktop\project>pyinstaller --additional-hooks-dir=hooks main.py
65 INFO: PyInstaller: 3.6
65 INFO: Python: 3.7.6 (conda)
65 INFO: Platform: Windows-10-10.0.18362-SP0
65 INFO: wrote C:\Users\miche\Desktop\project\main.spec
65 INFO: UPX is not available.
81 INFO: Extending PYTHONPATH with paths
['C:\\Users\\miche\\Desktop\\project', 'C:\\Users\\miche\\Desktop\\project']
81 INFO: checking Analysis
81 INFO: Building Analysis because Analysis-00.toc is non existent
81 INFO: Initializing module dependency graph...
81 INFO: Caching module graph hooks...
81 INFO: Analyzing base_library.zip ...
3232 INFO: Caching module dependency graph...
3326 INFO: running Analysis Analysis-00.toc
3343 INFO: Adding Microsoft.Windows.Common-Controls to dependent assemblies of final executable
required by c:\users\miche\anaconda3\envs\envpdf\python.exe
3608 INFO: Analyzing C:\Users\miche\Desktop\project\main.py
3624 INFO: Processing module hooks...
3624 INFO: Loading module hook "hook-encodings.py"...
3718 INFO: Loading module hook "hook-pydoc.py"...
3718 INFO: Loading module hook "hook-xml.py"...
3954 INFO: Loading module hook "hook-pdftotext.py"...
6537 INFO: Determining a mapping of distributions to packages...
29442 INFO: Packages required by pdftotext:
[]
33735 INFO: Looking for ctypes DLLs
33735 INFO: Analyzing run-time hooks ...
33746 INFO: Looking for dynamic libraries
34387 INFO: Looking for eggs
34387 INFO: Using Python library c:\users\miche\anaconda3\envs\envpdf\python37.dll
34390 INFO: Found binding redirects:
[]
34395 INFO: Warnings written to C:\Users\miche\Desktop\project\build\main\warn-main.txt
34430 INFO: Graph cross-reference written to C:\Users\miche\Desktop\project\build\main\xref-main.html
35274 INFO: checking PYZ
35274 INFO: Building PYZ because PYZ-00.toc is non existent
35274 INFO: Building PYZ (ZlibArchive) C:\Users\miche\Desktop\project\build\main\PYZ-00.pyz
35794 INFO: Building PYZ (ZlibArchive) C:\Users\miche\Desktop\project\build\main\PYZ-00.pyz completed successfully.
35802 INFO: checking PKG
35802 INFO: Building PKG because PKG-00.toc is non existent
35804 INFO: Building PKG (CArchive) PKG-00.pkg
35824 INFO: Building PKG (CArchive) PKG-00.pkg completed successfully.
35824 INFO: Bootloader c:\users\miche\anaconda3\envs\envpdf\lib\site-packages\PyInstaller\bootloader\Windows-64bit\run.exe
35824 INFO: checking EXE
35824 INFO: Building EXE because EXE-00.toc is non existent
35824 INFO: Building EXE from EXE-00.toc
35824 INFO: Appending archive to EXE C:\Users\miche\Desktop\project\build\main\main.exe
35824 INFO: Building EXE from EXE-00.toc completed successfully.
35875 INFO: checking COLLECT
35875 INFO: Building COLLECT because COLLECT-00.toc is non existent
35875 INFO: Building COLLECT COLLECT-00.toc
96644 INFO: Building COLLECT COLLECT-00.toc completed successfully.