- PLZ Python PIP alternative.
$ plz install pre-commit # Install 1 or more packages
$ plz uninstall pre-commit # Uninstall 1 or more packages
$ plz reinstall pre-commit # Reinstall 1 or more packages
$ plz download pre-commit # Download 1 or more packages
$ plz hash file.py # Show SHA CheckSum of file/package
$ plz init # New Python project template (Interactive)
$ plz stats # PyPI official service status report
$ plz newpackages # List all the new Packages uploaded to PyPI recently
$ plz lastupdates # List all existing Packages updated on PyPI recently
$ plz lastjobs # List all new Job Posts updated on Python recently
$ plz userpackages # List all existing Packages by User (Interactive)
$ plz latestversion # Show the Latest Version of a PYPI Package (SemVer)
$ plz forceInstallPip # Force install PIP on arbitrary folder (get-pip.py)
$ plz doc file.md # Markdown/ReSTructuredText to HTML (MD/RST can be mixed).
$ plz doc2latex file.md # Markdown/ReSTructuredText to Latex (MD/RST can be mixed).
$ plz doc2json file.md # Markdown/ReSTructuredText to JSON (MD/RST can be mixed).
$ plz upload packg-1.0.zip # Similar to "twine upload" (Interactive,asks user,wont need Twine).
$ plz parserequirements # Parse a requirements file, print it to stdout (Linter,Debug,etc).
$ plz fakecommits # Generate "Fake" Git commits (Restart CI,trigger GitHub Actions,etc).
$ plz bug # Python Bug Report Assistant (Interactive).
$
$ plz --enUsUtf8 # Force Encoding to UTF-8 and Language to English
$ plz --cleanpyc # Clean all __pycache__ and *.pyc
$ plz --cleanpypackages # Clean all __pypackages__
$ plz --cleantemp # Clean all temporary folder.
$ plz --cleanpipcache # Clean all PIP Cache folder.
$ plz --cleanvenvs # Clean Virtualenvs (interactive, asks Y/N 1-by-1).
$ plz --publicip # Show your Public IP Address (Internet connectivity check).
$ plz --log=file.log # Full path to a verbose local log file.
$ plz --putenv:key=val # Set an environment variable "KEY=Value", can be repeated.
$ plz --suicide # Deletes itself permanently and exit (single file binary).
$ plz --dump # Show system info JSON and quit (for Developers and Bug Reporting).
$ plz --version # Show Version
$ plz --help # Show Help
- Designed for Docker or Alpine usage.
- 1 Megabyte, 1 file, 0 Dependencies.
- Install, uninstall, reinstall, download, upload to PyPI, etc.
- Real Inferred Strong Static Typing.
- No Garbage Collector (Rust-like memory management).
- Immutable programming, No Global Mutable State.
- The only PIP alternative in the world that just works even with PIP/Python/Virtualenv completely broken.
- Compiled machine code performance, as fast as optimized hand crafted C.
- High performance with low resources (RPi, VPS, cloud, old pc, etc).
- Single file binary, it can even delete itself after use.
- No Installs, no setups, just copy & paste and run (even on Alpine).
- Colored output on the Terminal.
- Project skeleton creator to create your own new Python projects.
- Wont save any passwords, databases, keys, secrets, to disk nor Internet.
- No temporary folders nor files.
- Not meant as a drop-in replacement for anything pre-existing.
- Tiny single file source code (not counting string static constants).
- Self-Documentation Generator outputs HTML, PDF, JSON.
- Works fully independently self-contained standalone application.
WIP:
- Delete it.
- It does NOT depend on
pip
(Not apip
wrapper), it can work withpip
completely broken.
- Python 3.6+ 64Bit.
- This requires Cython ?.
No.
- This is a drop-in replacement of X ?.
No.
- Whats "Generate Fake Git Commits" ?.
Sometimes you may need to create commits to restart CI, trigger GitHub Actions, Git Hooks, etc but you dont have anything new to commit, that feature can create empty commits to force-trigger the Git service.
Some Git services do not trigger for new repos with 1 or 2 commits, that feature can create empty commits to force-start the Git service.
From XML-RPC API Server-side this endpoints wont work anymore (Not my Bug):
release_downloads
,top_packages
,updated_releases
,changed_packages
.- Sometimes PYPI returns Python Tracebacks as strings on the body of the response.
- We tried to implement fully parallel install of packages, but because of the way Python packages work, they need to be installed sequentially whatsoever.
Notes
- http://tonsky.me/blog/disenchantment
- https://medium.com/telnyx-engineering/rip-pipenv-tried-too-hard-do-what-you-need-with-pip-tools-d500edc161d4
- http://arindampaul.blogspot.com/2016/03/python-tips-avoid-pip-as-much-as.html
- pypa/pipenv#4058 (comment)
- https://chriswarrick.com/blog/2018/07/17/pipenv-promises-a-lot-delivers-very-little/
- https://old.reddit.com/r/Python/comments/chkah3/is_pipenv_dead_why_has_the_project_stopped/
- https://np.reddit.com/r/Python/comments/8jd6aq/why_is_pipenv_the_recommended_packaging_tool_by/
- https://github.com/pypa/pipenv/commit/6d77e4a0551528d5d72d81e8a15da4722ad82f26
- https://github.com/pypa/pipenv/commit/1c956d37e6ad20babdb5021610b2ed2c9c4203f2
- https://github.com/pypa/pipenv/commit/e3c72e167d21b921bd3bd89d4217b04628919bb2
- https://github.com/mitsuhiko/pipsi#pipsi (Dead Project)
- https://github.com/zachtylr21/pyp#pyp
- https://www.python.org/dev/peps/pep-0650
- https://pip.pypa.io/en/stable/news/#id1
Quote from PIPEnv Project:
pipenv release cadence came to a super dramatic halt because of a lot of upstream issues (pip broke, setuptools broke, then pip and setuptools both released breaking fixes, and we have about 15 dependencies which I personally maintain).
Quote from PIP Project:
Due to lack of interest and maintenance, 'pip bundle' and support for installing files is now deprecated.