Skip to content
You're viewing an older version of this GitHub Action. Do you want to see the latest version instead?
hard-drive

GitHub Action

Versatile PyInstaller

v1.2.0

Versatile PyInstaller

hard-drive

Versatile PyInstaller

Customisable GitHub Action to package python scripts into executables for different OS's

Installation

Copy and paste the following snippet into your .yml file.

              

- name: Versatile PyInstaller

uses: sayyid5416/pyinstaller@v1.2.0

Learn more about this action in sayyid5416/pyinstaller

Choose a version

Check all available usable tags here
You can also use any major tags like @v1 for any @v1.*.*


πŸ”° PyInstaller

  • This action packages the python source code into executables using pyinstaller.
  • Use this action in your workflow to create & upload executables to GitHub (as artifacts).
  • Use inputs to configure this action.
  • Use outputs to get information from this action.

πŸ”° Features

πŸ’  Multi-OS support

  • Create executable for different kinds of os like linux, windows, mac etc.
  • Specify OS in jobs.<job-id>.runs-on=<your-os-name> in your workflow file.
  • see examples for more info.

πŸ’  .py and .spec support

  • You can use either .py or .spec file to create the executable.
  • Specify it in inputs.spec: <file.py/file.spec>.
  • When .py file is used, generated .spec file will also be uploaded as artifact.
  • Modify your .spec file according to your needs.

πŸ’  Third party modules

  • Write your third party modules in a file (Ex: requirements.txt) , and
  • Use inputs.requirements: <path-to-your-requirement-file>.

πŸ’  Pyinstaller options

  • Specify pyinstaller options in inputs.options: <comma-seperated-options-here>.
  • .py and .spec both supports different kind of options.
  • Check list of all supported options here.

πŸ’  Python versions

  • You can specify any python version for the executable.
  • Specify specific python-version in inputs.python_ver: <python-version-here>.

πŸ’  Executable uploads

  • You can control if generated executable needs to be uploaded as artifact.
  • You can choose a name of your liking.
  • Specify the artifact name in inputs.upload_exe_with_name: <name-here>.

πŸ”° Inputs & Outputs

  • Some inputs are required, while rest are optional.
  • Check detailed info about these inputs & outputs here.

πŸ’  Available Inputs

Input Default
(- = empty string)
Description
spec (required) - Path of your .py or .spec file
requirements - Path of your requirements.txt file
options - Options to set for pyinstaller command
python_ver 3.10 Specific python version you want to use
exe_path ./dist Path on runner-os, where generated executable files are stored
upload_exe_with_name - If passed, uploads executable artifact with this name. Else, artifact won't be uploaded.

πŸ’  Available Outputs

Output Description
executable_path Path on runner-os, where generated executable files are stored
is_uploaded true, if packaged executable has been uploaded as artifact

πŸ’  Supported Pyinstaller options

For .py For .py For .py For .spec
--uac-admin --onedir, -D --upx-dir <UPX_DIR> --ascii, -a
--uac-uiaccess --onefile, -F --key <KEY> --upx-dir <UPX_DIR>
--noupx --ascii, -a --upx-exclude <FILE>
--console, --nowindowed, -c --name <NAME>, -n <NAME>
--windowed, --noconsole, -w --icon <FILEICON>, -i <FILEICON>

πŸ”° Examples

jobs:
  pyinstaller-build:
    runs-on: <windows-latest / ubuntu-latest / ..... etc>
    steps:
      - name: Create Executable
        uses: sayyid5416/pyinstaller@v1
        with:
          python_ver: '3.6'
          spec: 'src/build.spec'
          requirements: 'src/requirements.txt'
          upload_exe_with_name: 'My executable'
          options: --onefile, --name "My App", --windowed,