Skip to main content

psp (Python Scaffolding Projects)

Project description

Logo psp (Python Scaffolding Projects)

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.toml support
  • ๐Ÿค 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 gitignore file
  • ๐ŸŒŽ GitHub and Gitlab remote repository support
  • ๐Ÿ“‘ Create README, LICENSE, CONTRIBUTING, CODE_OF_CONDUCT and CHANGES files
  • ๐Ÿณ Create Dockerfile and Containerfile for your project
  • ๐Ÿ’ก Can use quick, simple and full argument for rapid configuration
  • ๐Ÿ’พ Create $HOME/.psp.env and $PWD/.env files with your customizations
  • ๐ŸŽ›๏ธ Can use some PSP_ variables to control your defaults
  • ๐Ÿ“ฆ Support pip, conda and uv package manager
  • ๐Ÿงฎ Support hatch, maturin and poetry builder

๐Ÿš€ Get Started in 30 Seconds

asciicast

psp

The result is:

$> tree wtf/ --filelimit=19 -a
wtf                     # 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
โ”œโ”€โ”€ wtf                 # Python package
โ”‚   โ””โ”€โ”€ __init__.py
โ”œโ”€โ”€ tests               # Tests package for modules
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ””โ”€โ”€ test_wtf.py     # Test module "test_<name_python_package>"
โ”œโ”€โ”€ tox.ini             # Tox configuration files
โ”œโ”€โ”€ samples
โ”‚   โ””โ”€โ”€ wtf_sample.py   # Sample code of package "<name_python_package>_sample"
โ””โ”€โ”€ .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 files

And git status is:

$> git status
On branch main

No commits yet
...
$> git remote get-url origin
git@github.com:MatteoGuadrini/test.git

Help

For help message, type:

$> psp help
psp (Python Scaffolding Projects), version 0.5.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"]
    
environments:
    Python version: 3.14

[!NOTE] More details for shortcuts, variables and other things, available in official documentation: psp docs

Why choose psp?

psp is simple, fast, effective, declarative, and supports Python and the entire ecosystem of tools written for it. Rather than replacing it, psp seeks to integrate and provide a useful scaffold for the end user.

Differences with other tools

  • cookiecutter: Users set configurations using JSON files when generating their projects.
  • PyScaffold: Provides a command-line interface to set up projects, typically yielding a compliant project structure, which can limit customization when using templates from other sources.

psp asks only what you need. By configuring a few environment variables, you can automate any project; in seconds, not hours.

๐Ÿ”Œ Prerequisites

psp has four mandatory prerequisetes installed on own machine:

  • git
  • python3
  • pip
  • curl (Linux/MacOS only)

MacOS prerequisites installation

/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
brew install python git

Windows prerequisites installation

winget install -e --id Git.Git
winget install -e --id Python.Python.3.14

Ubuntu based prerequisites installation

sudo apt install -y python3 python3-pip git curl

Red Hat based prerequisites installation

sudo dnf install -y python3 python3-pip git curl

Arch based prerequisites installation

sudo pacman -Qi python3 python3-pip git curl

๐Ÿ’ฟ Installation

๐Ÿ Python

To install with pip:

pip install psp-scaffold

Binary file

To install compiled file into your machine, download it:

Linux

For all users (required root access):

sudo -i
curl -L https://github.com/MatteoGuadrini/psp/releases/download/v0.5.0/psp_linux -o /usr/bin/psp
chmod +x /usr/bin/psp

For current user:

curl -L https://github.com/MatteoGuadrini/psp/releases/download/v0.5.0/psp_linux -o $HOME/.local/bin/psp
chmod +x $HOME/.local/bin/psp

MacOS

sudo su -
curl -L https://github.com/MatteoGuadrini/psp/releases/download/v0.5.0/psp_macos -o /usr/bin/psp
chmod +x /usr/bin/psp

Windows

For all users (required Administrator):

iwr -OutFile "C:\Windows\system32\psp.exe" "https://github.com/MatteoGuadrini/psp/releases/download/v0.5.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.5.0/psp_windows"

Packages

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.5.0/psp.deb -o psp.deb
sudo dpkg -i psp.deb

For Fedora/Mageia/OpenSuse:

sudo rpm -i https://github.com/MatteoGuadrini/psp/releases/download/v0.5.0/psp.rpm

Compile as your own

Instead, 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

or build with script:

git clone https://github.com/MatteoGuadrini/psp.git
cd psp 
# Build
./build_psp.sh
# Copy binary
sudo cp -v target/release/psp /usr/bin/psp && chmod +x /usr/bin/psp
# Install rpm
sudo rpm -i /tmp/psp_rpm/psp.rpm
# Instal deb
sudo dpkg -i /tmp/psp_deb/psp.deb

Docker/Podman

If you want to use psp in a containerized environment, follow this:

# Clone...
git clone https://github.com/MatteoGuadrini/psp.git
# Build...
cd psp && docker build . -t psp:latest
# Run...
docker run -it --rm -v ~/python_projects:/psp:z localhost/psp:latest

You can use .env files and environment variables:

# .env file
docker run -it --rm -v ~/python_projects:/psp:z -v ~/python_projects/.env:/psp/.env localhost/psp:latest
# PSP_ environment variables
docker run -it --rm -v ~/python_projects:/psp:z -e "PSP_GIT=true" -e "PSP_PYVER=1.0.0" localhost/psp:latest

๐Ÿงฐ Next features

  • windows operating system support
  • Container support for psp program
  • condaand uv support
  • hatch, maturin and poetry build support
  • docker-compose and kubernetes support
  • updating/merging project
  • templating folder support
  • command line flags support
  • YAML configuration file

Open source

psp is an open source project. Any contribution, It's welcome.

A great thanks.

For donations, press this

For me

paypal

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.

Adopt the future

Licence

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.

Buy us a tree

Acknowledgments

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!

Project details


Download files

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

Source Distribution

psp_scaffold-0.5.0.tar.gz (74.3 kB view details)

Uploaded Source

Built Distribution

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

psp_scaffold-0.5.0-py3-none-manylinux_2_39_x86_64.whl (1.0 MB view details)

Uploaded Python 3manylinux: glibc 2.39+ x86-64

File details

Details for the file psp_scaffold-0.5.0.tar.gz.

File metadata

  • Download URL: psp_scaffold-0.5.0.tar.gz
  • Upload date:
  • Size: 74.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: maturin/1.11.5

File hashes

Hashes for psp_scaffold-0.5.0.tar.gz
Algorithm Hash digest
SHA256 875cc80b92bb9943ee60fcca5957a44dbd2a50e5e10be15f5eb0a7ad9a972ba0
MD5 7b17a079bd2b4f9fc8139efcd1d1ae23
BLAKE2b-256 dac99306872f29f08e4f28da6d3c4364b64928400d684e1159a1ed78326f01cf

See more details on using hashes here.

File details

Details for the file psp_scaffold-0.5.0-py3-none-manylinux_2_39_x86_64.whl.

File metadata

File hashes

Hashes for psp_scaffold-0.5.0-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 36399e59094deb4668ed0e112d7b60c810d0bcf09d6d56fc75246fce465f057d
MD5 37907352ec8a937f204f5e28263641fb
BLAKE2b-256 664e9fd03529a0376cd754f78dc40108b09fd7e09cda33a7a179db1671584e3d

See more details on using hashes here.

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