Install Python packages from inside a Python environment. e.g. in Blender, Maya, Max, ...
The difference with existing solutions, py-pip solves an issue with the environment:
Blender ships with various python packages pre-installed in it's
python\libfolder.
But pip is not aware of these, e.g. thevenvpackage ships with Blender, but when runningpip show venvit doesn't detect it.
Also, any python paths added after Blender startup won't be detected by pip. e.g. various modules in the user site packages are added on startup.
If pip can't detect installed packages, it can result in packages being installed twice.
py-pip passes it's sys.paths to pip, which enables support for dynamicly added paths.
py-pip is designed as an API to be used by other python modules. some examples:
- pass env vars so pip can detect installed modules in different locations (e.g. Blender dynamicaly changes the Python path on startup)
& handle env vars, to prevent non sys.path paths being passed. - use pip from within Python, using the active interpreter
import py_pip
# optional
py_pip.default_target_path = "C:/path/to/site-packages" # defaults to no target path
py_pip.python_interpreter = "C:/path/to/python.exe" # defaults to sys.executable
# the core commands
py_pip.install("dummy_test") # install dummy_test
py_pip.uninstall("dummy_test") # uninstall the dummy_test packageBlender doesn't has an external Python interpreter that sets up the Blender environment (Maya has mayapy.exe).
To use pip and have it correctly detect the installed modules:
- you need to run it from inside Blender.
- or recreate the environment, with same Python version and Python paths.
Else you might install a module that is already by default installed in Blender, because pip failed to detect it.
This can result in clashes and weird bugs.
This might (untested) also be achievable by passing sys.path to os.environ["PYTHONPATH"] and then running one of the below modules.
Existing Python pip wrappers, without handling sys paths by default:
- 100⭐ di/pip-api - local
pip.exewrapper, lacks documentation (passes env vars, but not sys path, see code) - 004⭐ aescarias/pypiwrap - API wrapper for the PyPI website, not for local
pip.exedocumentation - 130⭐ sjkingo/virtualenv-api - local
pip.exewrapper, but for virtual env , nice quickstart docs on README - 7k⭐ pypa/pipx pip wrapper meant for commandline python apps. not really usefull for our use case.
- add support for pip auto remove - remove unused dependencies https://github.com/invl/pip-autoremove (does this use it s own uninstall, or can we get a list and use py-pip uninstall)