Максимальная ошибка рекурсии PyInstaller после перехвата предварительно безопасного модуля импорта [six.moves] - PullRequest
0 голосов
/ 28 апреля 2018

Я пытаюсь использовать PyInstaller для преобразования моего проекта python3.5 в файл .exe Мой основной файл SegTool.py

Это мой файл .spec:

# -*- mode: python -*-

block_cipher = None

a = Analysis(['SegTool.py'],
              pathex=['consts.py', 'FetalMRI_about.py', 'FetalMRI_mainwindow.py', 'FetalMRI_workspace.py', 'image_label.py', 'main_window.py', 'scan_file.py', 'segment3d_itk.py', 'Shapes.py', 'workspace.py', 'C:\\Users\\Keren Meron\\Documents\\School Work\\Fetal MRI\\FetalSegBrainTool'],
            binaries=[],
            datas=[('images', 'images')],
            hiddenimports=[],
            hookspath=[],
            runtime_hooks=[],
            excludes=[],
            win_n_no_prefer_redirects=False,
            win_private_assemblies=False,
            cipher=block_cipher)
pyz = PYZ(a.pure, a.zipped_data,
         cipher=block_cipher)
exe = EXE(pyz,
          a.scripts,
          exclude_binaries=True,
          name='SegTool',
          debug=False,
          strip=False,
          upx=True,
          console=True )
coll = COLLECT(exe,
           a.binaries,
           a.zipfiles,
           a.datas,
           strip=False,
           upx=True,
           name='SegTool')

Может быть, я не понимаю достаточно связанных хуков и зависимостей, но получаю сбой:

File "C:\Users\Keren Meron\WinPython-64bit-3.5.3.1Qt5\python-3.5.3.amd64\lib\ast.py", line 245, in visit
    return visitor(node)
File "C:\Users\Keren Meron\WinPython-64bit-3.5.3.1Qt5\python-3.5.3.amd64\lib\ast.py", line 253, in generic_visit
    self.visit(item)
File "C:\Users\Keren Meron\WinPython-64bit-3.5.3.1Qt5\python-3.5.3.amd64\lib\ast.py", line 245, in visit
    return visitor(node)
RecursionError: maximum recursion depth exceeded

Вывод (DEBUG и INFO включены) прямо перед трассировкой:

10923 INFO: Caching module hooks... 10937 INFO: Analyzing SegTool.py 13458 INFO: Processing pre-safe import module hook six.moves 14204 INFO: Processing pre-safe import module hook win32com 14205 DEBUG: win32com: extending __path__ with dir 'C:\\Users\\Keren Meron\\WinPython-64bit-3.5.3.1Qt5\\python-3.5.3.amd64\\lib\\site-packages\\win32comext' 14604 INFO: Processing pre-find module path hook distutils 16281 INFO: Processing pre-find module path hook site 16284 INFO: site: retargeting to fake-dir 'C:\\Users\\Keren Meron\\WinPython-64bit-3.5.3.1Qt5\\python-3.5.3.amd64\\lib\\site-packages\\PyInstaller\\fake-modules' 40968 INFO: Processing pre-safe import module hook requests.packages.urllib3.packages.six.moves 51591 DEBUG: load_module: SyntaxError in 'C:\\Users\\Keren Meron\\WinPython-64bit-3.5.3.1Qt5\\python-3.5.3.amd64\\lib\\site-packages\\jinja2\\asyncsupport.py'

Пожалуйста, помогите, что мне нужно сделать, чтобы это исправить?

Спасибо

1 Ответ

0 голосов
/ 28 августа 2018

Это может быть слишком поздно, но я тоже столкнулся с этой проблемой и исправил ее, добавив пару строк кода в файл спецификации вверху:

# -*- mode: python -*-
import sys
sys.setrecursionlimit(5000)

block_cipher = None

Надеюсь, это исправит и вашу проблему, если она все еще открыта!

...