We've recently added pycrypto to a project we've been working on and now I am unable to run the software after it is built with pyinstaller.
I have had issues with new packages in pyinstaller, but I am unable to fix this one in particular.
The errors I've gotten when trying to run the built software are as follows (sorry for the paraphrasing, it takes quite a while to build)
At first it was something like:
No package Crypto.Cipher
So I added 'Crypto'
to the hiddenimports
in my .spec file. Then I got,
No module named Cipher
So I changed 'Crypto'
to 'Crypto.Cipher'
and then I got,
Crypto.Cipher has no attribute AES
So I changed 'Crypto.Cipher'
to 'Crypto.Cipher.AES'
then I got
File "C:\Folder\made\by\pyinstaller\Crypto.Cipher.AES", line 49 in <module>
ImportError: cannot import name blockalgo
So I changed 'Crypto.Cipher.AES'
to 'Crypto.Cipher.AES.blockalgo'
and the error didn't change.
I've tried a few different configurations, but the output of the build script always says something along the lines of
ERROR: Hidden import 'blockalgo' not found.
Does anybody know how to get this to import correctly, or know a trick to get pycrypto to play nice with pyinstaller?
According to the pyinstaller manual:
You can verify that hidden import is the problem by using Python's verbose imports flag. If the import messages say "module not found", but the warnproject.txt file has no "no module named..." message for the same module, then the problem is a hidden import.
Hidden imports are handled by hooking the module (the one doing the hidden imports) at Analysis time. Do this as follows:
Create a file named hook-module.py (where module is the fully-qualified Python name, eg, hook-xml.dom.py) and place it somewhere. Remember the place as your private hooks directory.
In the .spec file, pass your private hooks directory as hookspath argument to Analysis so will be searched. Example:
a = Analysis(['myscript.py'], hookspath='/my/priv/hooks') In most cases the hook module will have only one line:
hiddenimports = ['module1', 'module2'] When the Analysis finds this file, it will proceed exactly as though the module explicitly imported module1 and module2.
This question seems related, the answers might also be useful for you.
Finally, this report seems to contain a similar problem. The user seemingly was able to fix it by updating to pyinstaller 2.1, so you might want to give that a try if you haven't already.