Gives you an overview of your Project structure
Go to file
Falko Victor Habel 7fe3e8a4c2
Run VectorLoader Script / Explore-Gitea-Actions (push) Successful in 8s Details
Gitea Actions For Tree-Structurer / Explore-Gitea-Actions (push) Successful in 21s Details
Merge pull request 'develop' (#14) from develop into main
Reviewed-on: #14
2025-02-09 11:16:18 +00:00
.gitea/workflows updated main 2025-02-09 11:46:02 +01:00
.vscode working generation script to generate proejct dirs with cli command create 2025-02-08 20:27:49 +01:00
src/prodir updated main 2025-02-09 11:46:02 +01:00
tests updated tests 2025-02-09 11:45:21 +01:00
.gitignore Initial commit 2025-01-18 21:37:27 +00:00
LICENSE Initial commit 2025-01-18 21:37:27 +00:00
README.md included creation examples 2025-02-09 12:12:08 +01:00
example.py overhall, added proper source dir and and improved code to not need python anymore and renaming it 2025-01-30 11:37:49 +01:00
pyproject.toml typo in realse version 2025-02-09 12:15:31 +01:00
pytest.ini fianlized tests and fixed errors if needed. Including improved error handling 2025-01-20 15:43:23 +01:00
requirements-dev.txt added missing yaml files 2025-01-20 15:46:36 +01:00
setup.cfg fianlized tests and fixed errors if needed. Including improved error handling 2025-01-20 15:43:23 +01:00
setup.py included creation examples 2025-02-09 12:12:08 +01:00

README.md

prodir

This is a Python package designed to display and create directory structures in a tree-like format. This tool provides an easy-to-read overview of the directory hierarchy, making it easier for developers to navigate complex project structures and automate the creation of directory layouts from predefined files.

Installation

To install prodir, you can use pip:

pip install git+https://gitea.fabelous.app/Fabel/prodir.git

Usage

You can run prodir from the command line. By default, it will analyze the current directory and print its structure in a tree-like format. You can also specify a path to another directory.

To display the directory structure of the current directory:

python -m prodir display

or

prodir

To display the directory structure of a specific directory:

python -m prodir display /path/to/directory

or

python -m prodir /path/to/directory

To create a directory structure from a file:

python -m prodir create /path/to/structure/file.txt -o /output/directory

or 

python -m prodir create /path/to/structure/file.txt #will create it in current dir

Options

  • -v or --verbose: Show more detailed output, including information about the path being analyzed.
  • -o or --output: Specify the output directory for the create command.

Examples:

python -m prodir display /path/to/directory -v

Important Files and Folders Ignored

By default, prodir ignores files and folders that start with _ or .. However, it does include the following exceptions:

  • __init__.py and __main__.py files: These are considered important and will be included in the output.
  • Special folders like build, .git, node_modules, etc.: These are also ignored to keep the output focused on the essential parts of the directory structure.

Example Input

project/
├── src/
│   ├── __init__.py
│   ├── main.py
│   ├── module1.py
│   └── module2.py
├── config/
│   └── config.yaml
├── .gitignore
├── pyproject.toml
├── setup.py
├── LICENSE
└── README.m

Example Output

LICENSE
README.m
config/
└── config.yaml
pyproject.toml
setup.py
src/
├── __init__.py
├── main.py
├── module1.py
└── module2.py

Commands

  • display: Displays the directory structure of a specified path or the current directory.

    • Usage: prodir display [path] [-v]
    • Example: python -m prodir display /path/to/directory
  • create: Creates a directory structure from a file containing the structure definition.

    • Usage: prodir create [file] [output_directory] [-v]
    • Example: python -m prodir create /path/to/structure/file.txt