Skip to main content

A lightweight Python library and CLI tool for displaying visually structured directory trees with optional emoji and exclusion filters.

Project description

๐Ÿ“๐ŸŒณ wintree

wintree is a Python library that displays the hierarchical structure of a specified directory in a tree format. It can be easily used from the command line, supports visually appealing tree views with emojis, and allows you to specify directories to exclude.

๐Ÿš€ Usage

๐Ÿ“š๏ธ As a Library

import wintree

print(wintree.tree())
# sample output
๐Ÿ“‚ root: .
โ”œโ”€โ”€ ๐Ÿ“„ .gitignore
โ”œโ”€โ”€ ๐Ÿ“„ README.md
โ”œโ”€โ”€ ๐Ÿ“„ pyproject.toml
โ”œโ”€โ”€ ๐Ÿ“ src/
โ”‚   โ”œโ”€โ”€ ๐Ÿ“ assets/
โ”‚   โ”‚   โ”œโ”€โ”€ ๐Ÿ“„ icon.png
โ”‚   โ”‚   โ””โ”€โ”€ ๐Ÿ“„ splash_android.png
โ”‚   โ””โ”€โ”€ ๐Ÿ“„ main.py
โ””โ”€โ”€ ๐Ÿ“ storage/
    โ”œโ”€โ”€ ๐Ÿ“ data/
    โ””โ”€โ”€ ๐Ÿ“ temp/

With arguments:

from wintree import tree

print(tree(root_dir="/path/to/project", use_emoji=True, ignore_dirs=[".git", "__pycache__"], filter_exts=[".py",".txt"]))
Argument Type Description
root_dir str Path to the root directory to start displaying the tree. Default is the current directory "."
use_emoji bool Whether to use emojis in the tree view. If True, adds icons to folders and files.
ignore_dirs List[str] List of directory names to exclude from the tree (partial match). Example: [".git", "node_modules"]
filter_ext List[str] File extensions to include. Example: [".py", "txt"]

Get or save as JSON

# Get as a dictionary
data = wintree.tree_to_dict(show_meta=True)

# Save as a JSON file
wintree.tree_to_json(root_dir="path/to/project" ,save_path="path/to/project_tree.json")

You can also list absolute paths instead of

import wintree

print(wintree.list_files())

โš™๏ธ Usage from CLI

wintree /path/to/project --exclude .git __pycache__

Options

Option Description
path Path to the root directory
--no-emoji Disable emoji display
--exclude Specify directory names to exclude (partial match, space-separated)
--ext File extensions to include

๐Ÿ“Œ Features

  • Emoji-based tree view for better visibility
  • Flexible exclusion of target directories
  • Supports Windows/macOS/Linux
  • Pure Python, no external dependencies

๐Ÿงช For Developers

This library can also be used as a base for directory visualization tools. Integration with GUI tools or IDE plugins is also possible.

๐Ÿ“„ License

MIT License

๐ŸŒ Language

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

wintree-0.1.8.tar.gz (5.0 kB view details)

Uploaded Source

Built Distribution

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

wintree-0.1.8-py3-none-any.whl (5.8 kB view details)

Uploaded Python 3

File details

Details for the file wintree-0.1.8.tar.gz.

File metadata

  • Download URL: wintree-0.1.8.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.12.0 Windows/11

File hashes

Hashes for wintree-0.1.8.tar.gz
Algorithm Hash digest
SHA256 276061526600f690edbf9409535032cb1ecabb6eaee8d634f5d371e0653d9baa
MD5 dd1464241ecb8f8d583ad16678812dd1
BLAKE2b-256 958304f6185601bd42b52177cf8d66a8a958fefe47ff26c9942991443e06d075

See more details on using hashes here.

File details

Details for the file wintree-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: wintree-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 5.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.12.0 Windows/11

File hashes

Hashes for wintree-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 72c164e73bb6fb4c35e8d4b555b859f6dfb7a4e532ff59812410ee74dc4a540c
MD5 cac55e9f6b2333f9a8aa747ac573c08f
BLAKE2b-256 13f1feacabe8cc04bddc2f8b252b8dec5e631b94f898436a3aae6733a2585a03

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