Skip to main content

Tree Implementation and Methods for Python, integrated with list, dictionary, pandas and polars DataFrame.

Project description

Big Tree Python Package

Tree Implementation and Methods for Python, integrated with list, dictionary, pandas and polars DataFrame.

It is pythonic, making it easy to learn and extendable to many types of workflows.


Related Links:


Components

There are 3 segments to Big Tree consisting of Tree, Binary Tree, and Directed Acyclic Graph (DAG) implementation.

For Tree implementation, there are 12 main components.

  1. 🌺 Node
    1. BaseNode, extendable class
    2. Node, BaseNode with node name attribute
  2. 🎄 Tree
    1. Tree, wrapper around Node, providing high-level APIs to build, iterate, query, and export the entire tree structure
  3. ✨ Constructing Tree
    1. From Node, using parent and children constructors
    2. From str, using tree display or Newick string notation
    3. From list, using paths or parent-child tuples
    4. From nested dictionary, using path-attribute key-value pairs or recursive structure
    5. From pandas DataFrame, using paths or parent-child columns
    6. From polars DataFrame, using paths or parent-child columns
    7. From interactive UI
    8. From rich trees
    9. Add nodes to existing tree using path string
    10. Add nodes and attributes to existing tree using dictionary, pandas DataFrame, or polars DataFrame, using path
    11. Add only attributes to existing tree using dictionary, pandas DataFrame, or polars DataFrame, using node name
  4. ➰ Traversing Tree
    1. Pre-Order Traversal
    2. Post-Order Traversal
    3. Level-Order Traversal
    4. Level-Order-Group Traversal
    5. ZigZag Traversal
    6. ZigZag-Group Traversal
  5. 🧩 Parsing Tree
    1. Get common ancestors between nodes
    2. Get path from one node to another node
  6. 📝 Modifying Tree
    1. Copy nodes from location to destination
    2. Shift nodes from location to destination
    3. Shift and replace nodes from location to destination
    4. Copy nodes from one tree to another
    5. Copy and replace nodes from one tree to another
  7. 📌 Querying Tree
    1. Filter tree using Tree Query Language
  8. 🔍 Tree Search
    1. Find multiple nodes based on name, partial path, relative path, attribute value, user-defined condition
    2. Find single nodes based on name, partial path, relative path, full path, attribute value, user-defined condition
    3. Find multiple child nodes based on user-defined condition
    4. Find single child node based on name, user-defined condition
  9. 🔧 Helper Function
    1. Cloning tree to another Node type
    2. Get subtree (smaller tree with different root)
    3. Prune tree (smaller tree with same root)
    4. Get difference between two trees
  10. 📊 Plotting Tree
  11. Enhanced Reingold Tilford Algorithm to retrieve (x, y) coordinates for a tree structure
  12. Plot tree using matplotlib (optional dependency)
  13. 🔨 Exporting Tree
  14. Print to console, in vertical or horizontal orientation
  15. Export to Newick string notation, dictionary, nested dictionary, pandas DataFrame, or polars DataFrame
  16. Export tree to dot (can save to .dot, .png, .svg, .jpeg files)
  17. Export tree to Pillow (can save to .png, .jpg)
  18. Export tree to Mermaid Flowchart (can display on .md)
  19. Export tree to Pyvis Network (can display interactive .html)
  20. ✔️ Workflows
  21. Sample workflows for tree demonstration!

For Binary Tree implementation, there are 4 main components. Binary Node inherits from Node, so the components in Tree implementation are also available in Binary Tree.

  1. 🌿 Node
    1. BinaryNode, Node with binary tree rules
  2. 🎄 Binary Tree
    1. BinaryTree, wrapper around BinaryNode, providing high-level APIs to build, iterate, query, and export the entire tree structure
  3. ✨ Constructing Binary Tree
    1. From list, using flattened list structure
  4. ➰ Traversing Binary Tree
    1. In-Order Traversal

For Directed Acyclic Graph (DAG) implementation, there are 6 main components.

  1. 🌼 Node
    1. DAGNode, extendable class for constructing Directed Acyclic Graph (DAG)
  2. 🎄 DAG
    1. DAG, wrapper around DAGNode, providing high-level APIs to build, export, and iterate the entire DAG
  3. ✨ Constructing DAG
    1. From list, containing parent-child tuples
    2. From nested dictionary
    3. From pandas DataFrame
  4. ➰ Traversing DAG
    1. Generic traversal method
  5. 🧩 Parsing DAG
    1. Get possible paths from one node to another node
  6. 🔨 Exporting DAG
    1. Export to list, dictionary, or pandas DataFrame
    2. Export DAG to dot (can save to .dot, .png, .svg, .jpeg files)

Installation

bigtree requires Python 3.10+. There are two ways to install bigtree, with pip (recommended) or conda.

a) Installation with pip

Basic Installation

To install bigtree, run the following line in command prompt:

$ pip install bigtree

Installing optional dependencies

bigtree have a number of optional dependencies, which can be installed using "extras" syntax.

$ pip install 'bigtree[extra_1, extra_2]'

Examples of extra packages include:

  • all: include all optional dependencies
  • image: for exporting tree to image
  • matplotlib: for plotting trees
  • pandas: for pandas methods
  • polars: for polars methods
  • query: for tree query methods
  • rich: for printing tree in rich format
  • vis: for pyvis visualisation

For image extra dependency, you may need to install more plugins.

$ brew install gprof2dot  # for MacOS
$ conda install graphviz  # for Windows

b) Installation with conda

To install bigtree with conda, run the following line in command prompt:

$ conda install -c conda-forge bigtree

Star History

Star History Chart

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

bigtree-1.3.1.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

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

bigtree-1.3.1-py3-none-any.whl (114.1 kB view details)

Uploaded Python 3

File details

Details for the file bigtree-1.3.1.tar.gz.

File metadata

  • Download URL: bigtree-1.3.1.tar.gz
  • Upload date:
  • Size: 1.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.3 cpython/3.14.3 HTTPX/0.28.1

File hashes

Hashes for bigtree-1.3.1.tar.gz
Algorithm Hash digest
SHA256 a22a0ecd9b0abb283f4a1515370dbf1ec93adee70746767272e2c49d7af9f407
MD5 9ae9395deb841da3effab3f768ef408a
BLAKE2b-256 d1aeac72cebb51b4d3180e44b20a52634c682b66bf7eaf7a0db2236db419f324

See more details on using hashes here.

File details

Details for the file bigtree-1.3.1-py3-none-any.whl.

File metadata

  • Download URL: bigtree-1.3.1-py3-none-any.whl
  • Upload date:
  • Size: 114.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.3 cpython/3.14.3 HTTPX/0.28.1

File hashes

Hashes for bigtree-1.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c8b766b00188c532d3499bfd9e9666b357428db507fc701f088031a0d5c614d5
MD5 d137cf1f4387f77e9149ccd0d21b3019
BLAKE2b-256 b3726102c002b1b4c04f8c5ed870f102f576a5fbd6a41cdb3e49ed339aa95dfe

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