Skip to main content

Converts .py to .exe using a simple graphical interface.

Project description

Auto PY to EXE

A .py to .exe converter using a simple graphical interface and PyInstaller in Python.

Empty interface

PyPI Version PyPI Supported Versions License Downloads Per Month Supported Platforms Donate

English | 简体中文 | Suomen kieli | Türkçe | فارسی | 한국어 | Български | हिन्दी | עברית | Беларуская | Slovenščina | српски | srpski

Demo

auto-py-to-exe Demo

Getting Started

Prerequisites

  • Python: 3.6-3.14

To have the interface displayed in the images, you will need Chrome. If Chrome is not installed or --default-browser is passed, the default browser will be used.

Installation and Usage

Installing via PyPI

You can install this project using PyPI:

$ pip install auto-py-to-exe

Then to run it, execute the following in the terminal:

$ auto-py-to-exe

If you have more than one version of Python installed, you can use python -m auto_py_to_exe instead of auto-py-to-exe.

Installing via GitHub

$ git clone https://github.com/brentvollebregt/auto-py-to-exe.git
$ cd auto-py-to-exe
$ python setup.py install

Then to run it, execute the following in the terminal:

$ auto-py-to-exe

Running Locally via Github (no install)

You can run this project locally by following these steps:

  1. Clone/download the repo
  2. Open cmd/terminal and cd into the project's root folder
  3. Execute python -m pip install -r requirements.txt
  4. Execute python -m auto_py_to_exe to run the application

Using the Application

  1. Select your script location (paste in or use a file explorer)
    • The outline will become blue if the file exists
  2. Select other options and add things like an icon or other files
  3. Click the big blue button at the bottom to convert
  4. Find your converted files in /output when completed

Easy.

Arguments

Use the help flag to get the usage: auto-py-to-exe --help

Argument Type Description
filename positional/optional Pre-fill the "Script Location" field in the UI.
-db, --default-browser optional Open the UI using the default browser (which may be Chrome). Will not try to find Chrome.
-nu, --no-ui optional Don't try to open the UI in a browser and simply print out the address where the application can be accessed.
-c [CONFIG], --config [CONFIG] optional Provide a configuration file (JSON) to pre-fill the UI. These can be generated in the settings tab.
-o [PATH], --output-dir [PATH] optional Set the default output directory. This can still be changed in the UI.
-bdo [FOLDER_PATH], --build-directory-override [FOLDER_PATH] optional Override the default build directory. Useful if you need to whitelist a folder to stop your antivirus from removing files.
-lang [LANGUAGE_CODE], --language [LANGUAGE_CODE] optional Hint the UI what language it should default to when opening. Language codes can be found in the table under "Translations" below.

JSON Configuration

Instead of inserting the same data into the UI over and over again, you can export the current state by going to the "Configuration" section within the settings tab and exporting the config to a JSON file. This can then be imported into the UI again to re-populate all fields.

This JSON config export action does not save the output directory automatically as moving hosts could mean different directory structures. If you want to have the output directory in the JSON config, add the directory under nonPyinstallerOptions.outputDirectory in the JSON file (will need to create a new key).

Examples

The examples/ directory offers some examples of how to write your scripts and package them with auto-py-to-exe.

Video

If you need something visual to help you get started, I made a video for the original release of this project; some things may be different but the same concepts still apply.

Contributing

Check out CONTRIBUTING.md to see guidelines on how to contribute. This outlines what to do if you have a new feature, a change, translation update or have found an issue with auto-py-to-exe.

Issues Using the Tool

If you're having issues with the packaged executable or using this tool in general, I recommend you read my blog post on common issues when using auto-py-to-exe. This post covers things you should know about packaging Python scripts and fixes for things that commonly go wrong.

If you believe you've found an issue with this tool, please follow the "Reporting an Issue" section in CONTRIBUTING.md.

Translations

Language Translators UI README CONTRIBUTING Examples
Arabic (العربية) Tayeb-Ali ✔️
Belarusian (Беларуская) Zmicier21 ✔️⚠️ ✔️
Brazilian Portuguese (Português Brasileiro) marleyas, reneoliveirajr ✔️
Bulgarian (Български) kbkozlev ✔️ ✔️
Chinese Simplified (简体中文) jiangzhe11 and Emptylight ✔️⚠️ ✔️ ✔️
Chinese Traditional (繁體中文) startgo ✔️
Czech (Čeština) Matto58 ✔️
Dutch (Nederlands) barremans ✔️
English - ✔️ ✔️ ✔️ ✔️
Finnish (Suomen kieli) ZapX5 ✔️ ✔️
French (Français) flaviedesp ✔️
German (Deutsch) hebens, ackhh ✔️
Greek (Ελληνικά) sofronas ✔️
Hebrew (עברית) ronbentata ✔️ ✔️
Hindi (हिन्दी) triach-rold ✔️ ✔️
Hungarian (Magyar) synexdev01 ✔️
Indonesian (Bahasa Indonesia) MarvinZhong ✔️
Italian (Italiano) itsEmax64 ✔️
Japanese (日本語) NattyanTV ✔️
Korean (한국어) jhk1090 ✔️ ✔️
Persian (فارسی) DrunkLeen, Ar.dst ✔️ ✔️
Polish (Polski) Akuczaku ✔️
Russian (Русский) Oleg ✔️
Serbian Cyrillic (српски) Radoš Milićev ✔️ ✔️ ✔️ ✔️
Serbian Latin (srpski) rina, Radoš Milićev ✔️ ✔️ ✔️ ✔️
Slovak (Slovenčina) mostypc123 ✔️
Slovenian (Slovenščina) Andrew Poženel ✔️ ✔️
Spanish (Español) enriiquee ✔️
Spanish Latin America (Español Latam) Matyrela ✔️
Thai (ภาษาไทย) teerut26 ✔️⚠️
Turkish (Türkçe) mcagriaksoy ✔️ ✔️
Ukrainian (Українська) AndrejGorodnij ✔️
Vietnamese (Tiếng Việt) 7777Hecker ✔️

Want to add a translation for another language? Follow the "Add or Update a Translation" section in CONTRIBUTING.md.

Python 2.7 Support

As of PyInstaller v4.0 released on Aug 9 2020, Python 2.7 is no longer supported; although you can still use this tool with Python 2.7 by installing an older version of PyInstaller. PyInstaller v3.6 was the last version that supported Python 2.7; to install this, first uninstall any existing versions of PyInstaller and then execute python -m pip install pyinstaller==3.6.

Testing

Tests are located in tests/ directory and are run using pytest:

$ pip install pytest
$ pip install -e .
$ pytest

Screenshots

Empty interface Filled out
Converting Completed

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

auto_py_to_exe-2.50.1.tar.gz (196.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

auto_py_to_exe-2.50.1-py2.py3-none-any.whl (198.0 kB view details)

Uploaded Python 2Python 3

File details

Details for the file auto_py_to_exe-2.50.1.tar.gz.

File metadata

  • Download URL: auto_py_to_exe-2.50.1.tar.gz
  • Upload date:
  • Size: 196.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for auto_py_to_exe-2.50.1.tar.gz
Algorithm Hash digest
SHA256 13dc388cfde0e00d265a3c71cfb54fd949d79fbf6195d8561462c364583fa559
MD5 6574beed0a3b4185c92106a2bc61b2c5
BLAKE2b-256 69866b6d90c4c77271448fa824311200610fb251431a0afb9506d67723b469d7

See more details on using hashes here.

Provenance

The following attestation bundles were made for auto_py_to_exe-2.50.1.tar.gz:

Publisher: publish.yml on brentvollebregt/auto-py-to-exe

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file auto_py_to_exe-2.50.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for auto_py_to_exe-2.50.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 94c661d397331fa70cf812767ce7f17d1a115992f2c90bacd9629034af81f949
MD5 1331fd0dca2b36b95b6196e68e3f5789
BLAKE2b-256 0d016fb5358f4755f99f9ce797e774fb1c80092f23f4b80465240ddf36cf6f75

See more details on using hashes here.

Provenance

The following attestation bundles were made for auto_py_to_exe-2.50.1-py2.py3-none-any.whl:

Publisher: publish.yml on brentvollebregt/auto-py-to-exe

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page