Skip to main content

PrintStruct: print project tree structure and optionally zip it

Reason this release was yanked:

This version is not stable, it was an accidental release

Project description

PrintStruct

PrintStruct is a clean, lightweight Python CLI that prints a directory tree of your project while respecting .gitignore, with optional zipping support.

The problems it solves:

  • sharing project structure in issues or pull requests
  • generating directory trees for documentation
  • pasting project layouts into LLMs
  • zipping projects for feeding to LLMs using .gitignore directions

Quick Start (10 seconds)

Installation using pip (recommended):

Run this command in your terminal:

pip install printstruct

Usage:

Open a terminal in any project and run:

prst

This prints the directory structure of the current folder.

You can also specify a path explicitly:

prst <directory_path>

Example (Windows PowerShell):

PS C:/Users/Projects/PrintStruct> prst .

Output:

PrintStruct
├─ LICENSE
├─ pyproject.toml
├─ README.md
├─ requirements.txt
└─ structure.py

Updating PrintStruct:

To update the tool, reinstall it using pip. Pip will automatically replace the older version with the latest release.


Useful CLI arguments

In addition to the directory path, the following options are available:

Argument Description
--version, -v Displays the installed version.
--zip [name] Zips the project while respecting .gitignore. Example: --zip a creates a.zip. If no name is provided, a random ID is used.
--max-depth Limits recursion depth. Example: --max-depth 1 shows only top-level files and folders.
--all, -a Includes hidden files and directories. Does not override .gitignore.
--ignore Adds extra files or directories to ignore.
--gitignore-depth Controls how deeply .gitignore files are discovered. Example: --gitignore-depth 0 uses only the root .gitignore.
--no-gitignore Ignores all .gitignore rules when set.
--max-items Limits items shown per directory. Extra items are summarized as ... and x more items. Default: 20.
--no-limit Removes the per-directory item limit.


Installation (for Contributors)

Clone the repository:

git clone https://github.com/ShahzaibAhmad05/PrintStruct

Move into the project directory:

cd PrintStruct

Install dependencies:

pip install -r requirements.txt

The tool is now available as a Python CLI on your system.


Contributions

Issues and pull requests are welcome. Ideas that would fit well include improved formatting, colorized output, test coverage, and performance optimizations.

PrintStruct is intentionally small and readable, so contributions that preserve simplicity are especially appreciated.

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

printstruct-1.3.0.tar.gz (4.0 kB view details)

Uploaded Source

Built Distribution

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

printstruct-1.3.0-py3-none-any.whl (4.5 kB view details)

Uploaded Python 3

File details

Details for the file printstruct-1.3.0.tar.gz.

File metadata

  • Download URL: printstruct-1.3.0.tar.gz
  • Upload date:
  • Size: 4.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for printstruct-1.3.0.tar.gz
Algorithm Hash digest
SHA256 569ad2a89f241e58474812bdc6a65b4c355c13e533d5ff98c394f803c26ee84a
MD5 390974b85100196613d2b8066a25c7ba
BLAKE2b-256 9625d8047ade7cc628a2ae8ff339906ee518d7df8a7c9ee1d2ab1280ff2dcb51

See more details on using hashes here.

Provenance

The following attestation bundles were made for printstruct-1.3.0.tar.gz:

Publisher: workflow.yml on ShahzaibAhmad05/PrintStruct

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file printstruct-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: printstruct-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 4.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for printstruct-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 87455b19dbe24512af107db258d9aaab04810a12c4d324f61bd2e4652f73de6e
MD5 ffe28814bed67dea32906e22319e5df2
BLAKE2b-256 af4bfcf8bb6ca9fdabe36facf090bfdff10c92d11df66a709a4b59f45377ff39

See more details on using hashes here.

Provenance

The following attestation bundles were made for printstruct-1.3.0-py3-none-any.whl:

Publisher: workflow.yml on ShahzaibAhmad05/PrintStruct

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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