Невозможно создать отдельный .exe-файл с модулем pdftotext. - PullRequest
1 голос
/ 31 марта 2020

Я пытаюсь преобразовать мой python скрипт, который содержит модуль pdftotext, в автономный .exe. Когда я тестирую .exe-приложение в моем анаконде env, оно работает правильно, но когда я тестирую его на другом устройстве, оно выдает мне эту ошибку:

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")

Извините за мой бедный английский sh, я из Италии. Я надеюсь, что проясняю себя, спасибо всем

РЕДАКТИРОВАТЬ 1. Я выяснил, что проблема может быть связана с poppler (библиотека используется pdftotext), но в настоящее время я не могу понять, какой файл подключается импортировать poppler

EDIT 2. После некоторой работы я обнаружил две вещи, которые могут помочь лучше понять мою ситуацию:

  1. Приложение .exe работает на моем устройстве ( даже за пределами анаконды, где я установил poppler и pdftotext), но он не работает на других устройствах (я пробовал два разных windows ноутбука, и ошибка та же); скрипт без 'pdftotext' работает на всех устройствах

  2. В папке dist (сборка с помощью pyinstaller) появляется отдельный файл с именем pdftotext: это файл 'pdftotext.cp37-win_amd64. pyd '(я не уверен, что это). В моем анаконде env есть только два файла, которые содержат строку «pdftotext»: «pdftotext.cp37-win_amd64.pyd» и «pdftotext.exe»

EDIT 3 Full ошибка при запуске 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.

1 Ответ

0 голосов
/ 01 апреля 2020

Вам нужен файл ловушки для PyInstaller. Чтобы процитировать документацию:

Таким образом, файл «ловушки» расширяет PyInstaller, чтобы адаптировать его к особым потребностям и методам, используемым пакетом Python. ... ... Они помогают фазе анализа находить необходимые файлы.

Официальные документы по хуку можно найти по адресу https://pyinstaller.readthedocs.io/en/stable/hooks.html.

Редактировать : должно работать следующее:

Создать эту структуру каталогов:

- yourcode.py
- hooks
  - hook-pdftotext.py

И в файле ловушек поставить следующее:

from PyInstaller.utils.hooks import collect_all

datas, binaries, hiddenimports = collect_all('pdftotext')

И затем построить с:

$ pyinstaller --additional-hook-dir=hooks yourcode.py
...