🚀 Release 4.0 adds support for 3rd-party packages to provide PyInstaller hooks along with the package. This allows Maintainers of other Python packages to deliver up-to-date PyInstaller hooks as part of their package.See our sample project for more information.
⚡️ PyInstaller uses this option itself to provide updated hooks much faster: Many hooks are moved into the new package pyinstaller-hooks-contrib which is updated monthly. This package is installed automatically when installing PyInstaller, but can also be updated independently.
👍 Finally, this version drops support for Python 2.7, which is end-of-life since January 2020.. The minimum required version is now Python 3.5. The last version supporting Python 2.7 was PyInstaller 3.6.
🚀 You can find a detailed list of changes in this release in the change log section of the manual.
👀 See https://pyinstaller.readthedocs.io/en/v3.6/CHANGES.html for Changelog.
👀 See https://pyinstaller.readthedocs.io/en/v3.5/CHANGES.html for Changelog.
👀 See https://pyinstaller.readthedocs.io/en/v3.4/CHANGES.html for Changelog.
- Fix imports in hooks accessible_output and sound_lib (#2860).
- 🛠 Fix ImportError for sysconfig for 3.5.4 Conda (#3105, #3106).
- 🛠 Fix shapely hook for conda environments on Windows (#2838).
- ➕ Add hook for unidecode.
- 🏁 (Windows) Pre-build bootloaders (and custom-build ones using MSVC) can be
🏁 used on Windows XP again. Set minimum target OS to XP (#2974).
🏗 Bootloader build
Usage: Add help-message clarifying use of options when a spec-file is
Add printing infos on UnicodeDecodeError in exec_command(_all).
(win32) Issue an error message on errors loading the icon file (#2039).
(aarch64) Use correct bootloader for 64-bit ARM (#2873).
(OS X) Fix replacement of run-time search path keywords (
- Fix recursion too deep errors cause by reimporting SWIG-like modules (#2911, #3040, #3061).
- Keep order of imported identifiers.
✅ Test-suite and Continuous Integration
👕 In Continuous Integration tests: Enable flake8-diff linting. This will
refuse all changed lines not following PEP 8.
🏁 Enable parallel testing on Windows,
⚡️ Update requirements.
➕ Add more test cases for modulegraph.
🛠 Fix a test-case for order of module import.
➕ Add test-cases to check scripts do not share the same global vars (see below).
➕ Add clarification about treatment of options when a spec-file is provided
➕ Add docs for running PyInstaller with Python optimizations (#2905).
➕ Add notes about limitations of Cython support.
➕ Add information how to handle undetected ctypes libraries.
➕ Add notes about requirements and restrictions of SWIG support.
➕ Add note to clarify what
➕ Add a Development Guide.
Extend "How to Contribute".
➕ Add "Running the Test Suite".
✂ Remove badges from the Readme (#2853).
⚡️ Update outdated sections in man-pages and other enhancements to the
📦 All scripts frozen into the package, as well as all run-time hooks, share
the same global variables. This issue exists since v3.2 but was discovered
👀 only lately, see #3037. This may lead to leaking global variables
from run-time hooks into the script and from one script to subsequent ones.
It should have effects in rare cases only, though.
🚀 Further see the Known Issues for release 3.3.
➕ Add command line option '--runtime-tmpdir'.
🏁 Bootloaders for Windows are now build using MSVC and statically linked with
the run-time-library (CRT). This solved a lot of issues related to .dlls
being incompatible with the ones required by
🐧 Bootloaders for GNU/Linux are now officially no LSB binaries. This was
🚀 already the case since release 3.1, but documented the other way round. Also
🏗 the build defaults to non-LSB binaries now. (#2369)
🏗 We improved and stabilized both building the bootloaders and the continuous
👀 integration tests. See below for details. Many thanks to all who worked on
📦 To ease solving issues with packages included wrongly, the html-file with a
cross-reference is now always generated. It's visual appearance has been
Command-line option obsoleted several version ago are not longer handled
gracefully but raise an error (#2413)
🚚 Installation: PyInstaller removed some internal copies of 3rd-party
🚀 packages. These are now taken from their official releases at PyPI (#2589).
This results in PyInstaller to no longer can be used from just an unpacked
📦 archive, but needs to be installed like any Python package. This should
effect only a few people, e.g. the developers.
🚀 Following :pep:
527, we only release one source archive now and decided to
🆕 New and Updated hooks: accessible_output2 (#2266), ADIOS (#2096), CherryPy
(#2112), PySide2 (#2471, #2744) (#2472), Sphinx (#2612, 2708) (#2708),
appdir (#2478), clr (#2048), cryptodome (#2125), cryptography (#2013), dclab
(#2657), django (#2037), django migrations (#1795), django.contrib (#2336),
google.cloud, google.cloud.storage, gstreamer (#2603), imageio (#2696),
langcodes (#2682), libaudioverse (#2709), mpl_toolkits (#2400), numba,
👕 llvmlite (#2113), openpyxl (#2066), pylint, pymssql, pyopencl, pyproj
✅ (#2677), pytest (#2119), qtawesome (#2617), redmine, requests (#2334),
setuptools, setuptools (#2565), shapely (#2569), sound_lib (#2267),
sysconfig, uniseg (#2683), urllib3, wx.rc (#2295),
osgeo: Add conda specific places to check for auxiliary data (#2401)
QT and related
- Add hooks for PySide2 - Eliminate run-time hook by placing files in the correct directory - Fix path in homebrew for searching for qmake ([#2354](https://github.com/pyinstaller/pyinstaller/pull/2354)) - Repair Qt dll location ([#2403](https://github.com/pyinstaller/pyinstaller/pull/2403)) - Bundle PyQT 5.7 DLLs ([#2152](https://github.com/pyinstaller/pyinstaller/issues/2152)) - PyQt5: Return qml plugin path including subdirectory ([#2694](https://github.com/pyinstaller/pyinstaller/issues/2694)) - Fix hooks for PyQt5.QtQuick ([#2743](https://github.com/pyinstaller/pyinstaller/pull/2743)) - PyQt5.QtWebEngineWidgets: Include files needed by QWebEngine
GKT+ and related
- Fix Gir file path on windows. - Fix unnecessary file search & generation when GI's typelib is exists - gi: change gir search path when running from a virtualenv - gi: package gdk-pixbuf in osx codesign agnostic dir - gi: rewrite the GdkPixbuf loader cache at runtime on Linux - gi: support onefile mode for GdkPixbuf - gi: support using gdk-pixbuf-query-loaders-64 when present - gi: GIR files are only required on OSX - gio: copy the mime.cache also - Fix hooks for PyGObject on windows platform ([#2306](https://github.com/pyinstaller/pyinstaller/pull/2306))
tempdiroption to control where bootloader will extract files (#2221)
🚀 (Windows) in releases posted on PyPI requires msvcr*.dll (#2343)
✂ Remove a left-over use of
Set proper LISTEN_PID (set by
systemd) in child process (#2345)
(Windows) Use _wputenv_s() instead of
🏁 (Windows) Enhance error messages (#1431)
🐧 (GNU/Linux) Compile bootloaders with --no-lsb by default (#2369)
🐧 (GNU/Linux) Fix: linux64 bootloader requires glibc 2.14 (#2160)
(GNU/Linux) set_dynamic_library_path change breaks plugin library use
🏗 Bootloader build
🏗 The bootloader build was largely overhauled. In the wscript, the build no
longer depends on the Python interpreter's bit-size, but on the compiler. We
🏁 have a machine for building bootloaders for Windows and cross-building for
🏗 OS X. Thus all mainteriner are now able to build the bootloaders for all
👌 supported platforms.
➕ Add "official" build-script.
🐧 (GNU/Linux) Make --no-lsb the default, add option --lsb.
Largely overhauled Vagrantfile:
- Make Darwin bootloaders build in OS X box (unused)
- Make Windows bootloaders build using MSVC
- Allow specifying cross-target on linux64.
- Enable cross-building for OS X.
- Enable cross-building for Windows (unused)
- Add box for building osxcross.
Largely overhauled wscript:
- Remove options --target-cpu.
- Use compiler's target arch, not Python's.
- Major overhaul of the script
- Build zlib if required, not if "on windows".
- Remove obsolete warnings.
- Update Solaris, AIX and HPUX support.
- Add flags for 'strip' tool in AIX platform.
- Don't set POSIX / SUS version defines.
🐧 (GNU/Linux) for 64-bit arm/aarch ignore the :program:
- Implement PEP-451 ModuleSpec type import system (#2377)
- 🛠 Fix: Import not thread-save? (#2010, #2371)
✅ Analyze: Check Python version when testing whether to rebuild.
Analyze: Don't fail on syntax error in modules, simply ignore them.
👍 Better error message when
datasare not found. (#2308)
🏗 Building: OSX: Use unicode literals when creating Info.plist XML
🏗 Building: Don't fail if "datas" filename contain glob special characters.
🏗 Building: Read runtime-tmpdir from .spec-file.
⚡️ Building: Update a comment.
🏗 building: warn users if bincache gets corrupted. (#2614)
🚚 Cli-utils: Remove graceful handling of obsolete command line options.
🔧 Configure: Create new parent-dir when moving old cache-dir. (#2679)
🏁 Depend: Include vcruntime140.dll on Windows. (#2487)
🖨 Depend: print nice error message if analyzed script has syntax error.
🚚 Depend: When scanning for ctypes libs remove non-basename binaries.
✨ Enhance run-time error message on ctypes import error.
🛠 Fix crash if extension module has hidden import to ctypes. (#2492)
🛠 Fix handling of obsolete command line options. (#2411)
🛠 Fix versioninfo.py breakage on Python 3.x (#2623)
🛠 Fix: "Unicode-objects must be encoded before hashing" (#2124)
Fix: UnicodeDecodeError - collect_data_files does not return filenames as
✂ Remove graceful handling of obsolete command line options. (#2413)
🏁 Make grab version more polite on non-windows (#2054)
👉 Make utils/win32/versioninfo.py round trip the version info correctly.
👉 Makespec: Fix version number processing for PyCrypto. (#2476)
♻️ Optimizations and refactoring to modulegraph and scanning for ctypes
pyinstaller should not crash when hitting an encoding error in source code
✂ Remove destination for COLLECT and EXE prior to copying it (#2701)
✂ Remove uninformative traceback when adding not found data files (#2346)
threading bug while processing imports (#2010)
utils/hooks: Add logging to collect_data_files.
👍 (win32) Support using pypiwin32 or pywin32-ctypes (#2602)
(win32) Use os.path.normpath to ensure that system libs are excluded.
🏁 (win32) Look for libpython%.%.dll in Windows MSYS2 (#2571)
(win32) Make versioninfo.py round trip the version info correctly (#2599)
(win32) Ensure that pywin32 isn't imported before check_requirements is
(win32) pyi-grab_version and --version-file not working? (#1347)
(win32) Close PE() object to avoid mmap memory leak (#2026)
🏁 (win32) Fix: ProductVersion in windows version info doesn't show in some
(win32) Fix multi-byte path bootloader import issue with python2 (#2585)
(win32) Forward DYLD_LIBRARY_PATH through
vcruntime140.dllto_win_includes for Python 3.5 an 3.6
(OS X) Add libpython%d.%dm.dylib to Darwin (is_darwin) PYDYLIB_NAMES.
🍎 (OS X) macOS bundle Info.plist should be in UTF-8 (#2615)
🍎 (OS X) multiprocessing spawn in python 3 does not work on macOS (#2322)
- Align with upstream version 0.13.
- Add the upstream test-suite
- Warn on syntax error and unicode error. (#2430)
- Switch byte-code analysis to use
Instruction(like dis3 does) (#2423)
- Log warning on unicode error instead of only a debug message (#2418)
- Use standard logging for messages. (#2433)
- Fix to reimport failed SWIG C modules (1522, #2578).
Included 3rd-party libraries
- Remove bundled
macholib, use the releases from PyPI.
- altgraph: Update to altgraph 0.13, add upstream test-suite.
✅ Test-suite and Continuous Integration
Rearrange requirements files.
⚡️ Pin required versions – now updated using pyup (#2745)
Hide useless trace-backs of helper-functions.
➕ Add a test for PyQt5.QtQuick.
➕ Add functional tests for PySide2
➕ Add test for new feature --runtime-tmpdir.
🛠 Fix regression-test for #2492.
✅ unit: Add test-cases for PyiModuleGraph.
✅ unit/altgraph: Bringing in upstream altgraph test-suite.
✅ unit/modulegraph: Bringing in the modulegraph test-suite.
- Lots of enhancements to the CI tests to make them more stabile and
- Pin required versions – now updated using pyup (#2745)
- OS X is now tested along with GNU/Linux at Travis CI (#2508)
- Travis: Use stages (#2753)
- appveyor: Save cache on failure (#2690)
- appveyor: Verify built bootloaders have the expected arch.
- ➕ Add information how to donate (#2755, #2772).
- ➕ Add how to install the development version using pip.
- 🛠 Fix installation instructions for development version. (#2761)
- 👍 Better examples for hidden imports.
- Clarify and fix "Adding Data Files" and "Adding Binary Files". (#2482)
- 💻 Document new command line option '--runtime-tmpdir'.
- 🐧 pyinstaller works on powerpc linux, big endian arch (#2000)
- ⚡️ Largely rewrite section "Building the Bootloader", update from the wiki
- 🏗 Describe building LSB-compliant bootloader as (now) special case.
- help2rst: Add cross-reference labels for option-headers.
- Enable sphinx.ext.intersphinx and links to our website.
- 📚 Sphinx should not "adjust" display of command line documentation (#2217)
Data-files from wheels, unzipped eggs or not ad egg at all are not included
automatically. This can be worked around using a hook-file, but may not
suffice when using
--onefileand something like
📦 The multipackage (MERGE) feature (#1527) is currently broken.
👍 (OSX) Support for OpenDocument events (#1309) is broken.
🏁 (Windows) With Python 2.7 the frozen application may not run if the
👉 user-name (more specifically
%TEMPDIR%) includes some Unicode
characters. This does not happen with all Unicode characters, but only some
⬆️ and seems to be a windows bug. As a work-around please upgrade to Python 3
🏁 (Windows) For Python >= 3.5 targeting Windows < 10, the developer needs to
👀 take special care to include the Visual C++ run-time .dlls. Please see the
🏁 section :ref:
Platform-specific Notes <Platform-specific Notes - Windows>
in the manual. (#1566)
For Python 3.3, imports are not thread-safe (#2371#). Since Python 3.3 is
end of live at 2017-09-29, we are not going to fix this.
- 🆕 New, updated and fixed hooks: botocore (#2094), gi (#2347), jira (#2222),
PyQt5.QtWebEngineWidgets (#2269), skimage (#2195, 2225), sphinx (#2323,)
🛠 Fixed the following issues:
- Don't fail if working directory already exists (#1994)
- Avoid encoding errors in main script (#1976)
- 🛠 Fix hasher digest bytes not str (#2229, #2230)
- 🏁 (Windows) Fix additional dependency on the msvcrt10.dll (#1974)
- 🏁 (Windows) Correctly decode a bytes object produced by pefile (#1981)
- 🏁 (Windows) Package
pefilewith pyinstaller. This partially
📦 undoes some changes in 3.2 in which the packaged pefiles were
✂ removed to use the pypi version instead. The pypi version was
considerably slower in some applications, and still has a couple
of small issues on PY3. (#1920)
- 🍎 (OS X) PyQt5 packaging issues on MacOS (#1874)
- (OS X) Replace run-time search path keyword (#1965)
- (OS X) (Re-) add argv emulation for OSX, 64-bit (#2219)
- (OS X) use decode("utf-8") to convert bytes in getImports_macholib() (#1973)
- (Bootloader) fix segfaults (#2176)
- 🐧 (setup.py) pass option --no-lsb on GNU/Linux only (#1975)
- 📚 Updates and fixes in documentation, manuals, et al. (#1986, 2002, #2153,
- 🆕 New, updated and fixed hooks: botocore (#2094), gi (#2347), jira (#2222),
- Even the "main" script is now byte-compiled (#1847, #1856)
- The manual is on readthedocs.io now (#1578)
- On installation try to compile the bootloader if there is none for the current plattform (#1377)
- (Unix) Use
objcopyto create a valid ELF file (#1812, #1831)
- (Linux): Compile with
- 🆕 New, updated and fixed hooks: CherryPy (#1860), Cryptography (#1425, #1861), enchant (1562), gi.repository.GdkPixbuf (#1843), gst (#1963), Lib2to3 (#1768), PyQt4, PyQt5, PySide (#1783, #1897, #1887), SciPy (#1908, #1909), sphinx (#1911, #1912), sqlalchemy (#1951), traitlets wx.lib.pubsub (#1837, #1838),
- For windowed mode add
isatty()for our dummy NullWriter (#1883)
- Suppress "Failed to execute script" in case of SystemExit (#1869)
- Do not apply Upx compressor for bootloader files (#1863)
- 🛠 Fix absolute path for lib used via ctypes (#1934)
- (OSX) Fix binary cache on NFS (#1573, #1849)
- 🏁 (Windows) Fix message in grab_version (#1923)
- 🏁 (Windows) Fix wrong icon paramter in Windows example (#1764)
- 🏁 (Windows) Fix win32 unicode handling (#1878)
- 🏁 (Windows) Fix unnecessary rebuilds caused by rebuilding winmanifest (#1933)
- (Cygwin) Fix finding the Python library for Cygwin 64-bit (#1307, #1810, #1811)
- (OSX) Fix compilation issue (#1882)
- 🏁 (Windows) No longer bundle
pefile, use package from for windows (#1357)
- 🏁 (Windows) Provide a more robust means of executing a Python script
- 🛠 AIX fixes.
- ⚡️ Update waf to version 1.8.20 (#1868)
- 🛠 Fix excludedimports, more predictable order how hooks are applied #1651
- Internal impovements and code clean-up (#1754, #1760, #1794, #1858, #1862, #1887, #1907, #1913)
- ✅ Clean-ups fixes and improvements for the test suite