Distributing Your Application to Other Systems/Platforms¶
After developing a couple of applications, you might want to distribute them to other users. In case you do not have much experience with Python packages, you might have even asked: How do I create a Python executable?.
If you come from compiled programming languages, deployment is something almost trivial, but for Python is a bit difficult.
The deployment process for Python applications is called, “freezing”, which is distributing your virtual environment content to other users.
Important
As Python does not support WebAssembly and mobile platforms, such as Android and iOS, you cannot deploy applications to these platforms directly, and you require advanced processes to do so.
Note
For embedded systems, you currently need to build Qt for Python for your target platform, and deploy the installation alongside your application.
Reproducible deployment¶
A common approach is to only provide a requirements.txt
file, where you
state your dependencies. Users would need to install them from there
to run your Application.
For example, imagine I have a project with two dependencies, module_a
and
module_b
, which I use in my main.py
file. So my structure is:
# Content of the main.py file
from module_a import something
import module_b
# ...
So the requirements.txt
for my application would look like this:
module_a
module_b
Later, when a user want to execute your main.py
, the dependencies
must be installed using pip install -r requirements.txt
in a new virtual environment.
Important
You can notice that this approach includes sharing your code so it fails if you want to hide the code of your application.
Freezing Your Application¶
This is the most common approach for users to distribute their applications and even though the code is still available for the end user, it is a bit more difficult to retrieve it.
You can find a series of tutorials based on the most popular tools that allow Python users to freeze and distribute applications in our Qt for Python Deployment section.
Compiling Python¶
Even though Python does not natively support to be compiled, there are complementary tools that let you to achieve this. You can check the Nuitka project to learn more.
© 2022 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.