psp is a blazing fast command line utility to scaffold your Python project, written in Rust.
- ⚡️ 1-100x faster compared to other scaffolding tools
- 🛠️
pyproject.tomlsupport - 🤝 Python 3.14 compatibility
- 🗃 Scaffolding file and folder structures for your Python project
- 📦 Unit-test and pytest support
- 🧪 Create a virtual environment
- 🔧 Automagically dependencies installation
- 🪛 Add build and deploy dependencies to distribute the package
- 📏 tox configuration supports and remotes CI like CircleCI and TravisCI
- ⌨️ MkDocs and Sphinx documentation support
- 🧰 Initialize git repository and
gitignorefile - 🌎 GitHub and Gitlab remote repository support
- 📑 Create
README,LICENSE,CONTRIBUTING,CODE_OF_CONDUCTandCHANGESfiles - 🐳 Create
DockerfileandContainerfilefor your project - 💡 Can use quick, simple and full argument for rapid configuration
- 💾 Create
$HOME/.psp.envand$PWD/.envfiles with your customizations - 🎛️ Can use some
PSP_variables to control your defaults
The result is:
$> tree test/ --filelimit=19 -a
test # Project folder
├── LICENSE.md # License file
├── pyproject.toml # Python package configuration file
├── README.md # Readme file
├── CHANGES.md # List of changes
├── .circleci # CI folder
│ └── config.yml # CI configuration file
├── CODE_OF_CONDUCT.md # Code of Conduct
├── CONTRIBUTING.md # Contributing guide lines
├── Containerfile # Standard container file for build image
├── Dockerfile # Docker container file for build image
├── Makefile # Makefile for command make; make help
├── requirements.txt # Dependencies list used by third programs
├── docs # Documentation folder: Sphinx/MKDocs
│ ├── build
│ ├── make.bat
│ ├── Makefile
│ └── source
│ ├── conf.py
│ ├── index.rst
│ ├── _static
│ └── _templates
├── .git # Git folder
│ ├── branches
│ ├── config
│ ├── description
│ ├── HEAD
│ ├── hooks [14 entries exceeds filelimit, not opening dir]
│ ├── info
│ │ └── exclude
│ ├── objects
│ │ ├── info
│ │ └── pack
│ └── refs
│ ├── heads
│ └── tags
├── .github # Github issue and merge templates
│ ├── ISSUE_TEMPLATE
│ │ ├── bug.yml
│ │ ├── config.yml
│ │ └── feature.yml
│ └── PULL_REQUEST_TEMPLATE
│ └── pull_request_template.md
├── .gitignore # Git ignore file
├── .dockerignore # Docker ignore file
├── .containerignore # Container ignore file
├── test # Python package
│ └── __init__.py
├── tests # Tests package for modules
│ ├── __init__.py
│ └── test_test.py # Test module "test_<name_python_package>"
├── tox.ini # Tox configuration files
└── venv # Virtual environment
├── bin [33 entries exceeds filelimit, not opening dir]
├── include
│ └── python3.14
├── lib
│ └── python3.14
│ └── site-packages [68 entries exceeds filelimit, not opening dir]
├── lib64 -> lib
└── pyvenv.cfg
29 directories, 44 filesAnd git status is:
$> git status
On branch main
No commits yet
...
$> git remote get-url origin
[email protected]:MatteoGuadrini/test.gitFor help message, type:
$> psp help
psp (Python Scaffolding Projects), version 0.3.0
usage: psp [shortcut]
ie: psp [help|quick|simple|full]
shortcut:
help: print this help message
quick: enables a rapid setup (few options included)
simple: enables a basic setup (only Python package)
full: enables a full setup (all options)
links:
repository: https://github.com/MatteoGuadrini/psp
documentation: https://psp.readthedocs.io/
variables:
["PSP_GIT","PSP_GIT_REMOTE","PSP_GIT_USER"]Note
More details for shortcuts, variables and other things, available in official documentation: psp docs
psp has four mandatory prerequisetes installed on own machine:
gitpython3pipcurl(Linux/MacOS only)
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
brew install python gitwinget install -e --id Git.Git
winget install -e --id Python.Python.3.14sudo apt install -y python3 python3-pip git curlsudo dnf install -y python3 python3-pip git curlsudo pacman -Qi python3 python3-pip git curlTo install compiled file into your machine, download it:
For all users (required root access):
sudo -i
curl -L https://github.com/MatteoGuadrini/psp/releases/download/v0.3.0/psp_linux -o /usr/bin/psp
chmod +x /usr/bin/pspFor current user:
curl -L https://github.com/MatteoGuadrini/psp/releases/download/v0.3.0/psp_linux -o $HOME/.local/bin/psp
chmod +x $HOME/.local/bin/pspsudo su -
curl -L https://github.com/MatteoGuadrini/psp/releases/download/v0.3.0/psp_macos -o /usr/bin/psp
chmod +x /usr/bin/pspFor all users (required Administrator):
iwr -OutFile "C:\Windows\system32\psp.exe" "https://github.com/MatteoGuadrini/psp/releases/download/v0.3.0/psp_windows"For current user:
mkdir "$($Env:USERPROFILE)\bin"
[System.Environment]::SetEnvironmentVariable("PATH", $Env:PATH + ";$($Env:USERPROFILE)\bin","USER")
iwr -OutFile "$($Env:USERPROFILE)\bin\psp.exe" "https://github.com/MatteoGuadrini/psp/releases/download/v0.3.0/psp_windows"If you want to install OS package, follow instructions for your Operating System:
For Debian/Ubuntu:
curl -L https://github.com/MatteoGuadrini/psp/releases/download/v0.3.0/psp.deb -o psp.deb
sudo dpkg -i psp.debFor Fedora/Mageia/OpenSuse:
sudo rpm -i https://github.com/MatteoGuadrini/psp/releases/download/v0.3.0/psp.rpmInstead, if you compile this project as own, follow this steps:
git clone https://github.com/MatteoGuadrini/psp.git
cd psp && cargo build --release && sudo cp -v target/release/psp /usr/bin/psp && chmod +x /usr/bin/psp-
windowsoperating system support - Container support for psp program
-
conda,uvandpoetrysupport -
hatchsupport -
docker-composeandkubernetessupport - command line flags support
- updating/merging project
- templating folder support
- YAML configuration file
psp is an open source project. Any contribution, It's welcome.
A great thanks.
For donations, press this
For me
For Telethon
The Telethon Foundation is a non-profit organization recognized by the Ministry of University and Scientific and Technological Research. They were born in 1990 to respond to the appeal of patients suffering from rare diseases. Come today, we are organized to dare to listen to them and answers, every day of the year.
This package is Treeware. If you use it in production, then we ask that you buy the world a tree to thank us for our work. By contributing to the Treeware forest you’ll be creating employment for local families and restoring wildlife habitats.
Thanks to Jim Blandy, Jason Orendorff and Nora Tindall for writing the Programming Rust book that make up my Rust foundation.
Thanks to Tim McNamara for writing the Rust in Action book.
Thanks to Zed IDE and for license of RustRover offered by Jetbrains.
Special thanks go to my wife, who understood the hours of absence for this development. Thanks to my children, for the daily inspiration they give me and to make me realize, that life must be simple.
Thanks, Rust Community!

