Skip to main content

Utilities for implementing Modified Preorder Tree Traversal with your Django Models and working with trees of Model instances.

Project description

This project is currently unmaintained

Alternatives to django-mptt include:

  • django-treebeard includes a MPTT implementation (called nested set), but the state of maintenance is unclear.

  • Maybe you do not need MPTT, especially when using newer databases. See django-tree-queries for an implementation using recursive Common Table Expressions (CTE). See the announcement blog post.

django-mptt

Utilities for implementing Modified Preorder Tree Traversal with your Django Models and working with trees of Model instances.

Build Status

Project home: https://github.com/django-mptt/django-mptt/

Documentation: https://django-mptt.readthedocs.io/

Discussion group: https://groups.google.com/forum/#!forum/django-mptt-dev

What is Modified Preorder Tree Traversal?

MPTT is a technique for storing hierarchical data in a database. The aim is to make retrieval operations very efficient.

The trade-off for this efficiency is that performing inserts and moving items around the tree is more involved, as there’s some extra work required to keep the tree structure in a good state at all times.

Here are a few articles about MPTT to whet your appetite and provide details about how the technique itself works:

What is django-mptt?

django-mptt is a reusable Django app which aims to make it easy for you to use MPTT with your own Django models.

It takes care of the details of managing a database table as a tree structure and provides tools for working with trees of model instances.

Requirements

  • Python 3.6+

  • A supported version of Django (currently 2.2+)

Feature overview

  • Simple registration of models - fields required for tree structure will be added automatically.

  • The tree structure is automatically updated when you create or delete model instances, or change an instance’s parent.

  • Each level of the tree is automatically sorted by a field (or fields) of your choice.

  • New model methods are added to each registered model for:

    • changing position in the tree

    • retrieving ancestors, siblings, descendants

    • counting descendants

    • other tree-related operations

  • A TreeManager manager is added to all registered models. This provides methods to:

    • move nodes around a tree, or into a different tree

    • insert a node anywhere in a tree

    • rebuild the MPTT fields for the tree (useful when you do bulk updates outside of django)

  • Form fields for tree models.

  • Utility functions for tree models.

  • Template tags and filters for rendering trees.

  • Admin classes for visualizing and modifying trees in Django’s administration interface.

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

django-mptt-0.14.0.tar.gz (103.5 kB view details)

Uploaded Source

Built Distribution

django_mptt-0.14.0-py3-none-any.whl (115.6 kB view details)

Uploaded Python 3

File details

Details for the file django-mptt-0.14.0.tar.gz.

File metadata

  • Download URL: django-mptt-0.14.0.tar.gz
  • Upload date:
  • Size: 103.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.10.6

File hashes

Hashes for django-mptt-0.14.0.tar.gz
Algorithm Hash digest
SHA256 2c92a2b1614c53086278795ccf50580cf1f9b8564f3ff03055dd62bab5987711
MD5 c878dd6f0d18ea552563d29d27424e72
BLAKE2b-256 73e19e7de6bfb03d2243541613caefc5aa7068ee408257ba6952153ac323610f

See more details on using hashes here.

File details

Details for the file django_mptt-0.14.0-py3-none-any.whl.

File metadata

  • Download URL: django_mptt-0.14.0-py3-none-any.whl
  • Upload date:
  • Size: 115.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.10.6

File hashes

Hashes for django_mptt-0.14.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d9a87433ab0e4f35247c6f6d5a93ace6990860a4ba8796f815d185f773b9acfc
MD5 b9f92677ecc4b3f1238b60677b2e9f23
BLAKE2b-256 d305386abcef8161ea9cf34bb1392659b0d690b07d5811d768dd4d9c40df8440

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page