Skip to main content

MongoDB aggregation pipelines made easy. Joins, grouping, counting and much more...

Project description

📊 Monggregate

📋 Overview

Monggregate is a library that aims at simplifying usage of MongoDB aggregation pipelines in Python. It's a lightweight QueryBuilder for MongoDB aggregation pipelines based on pydantic and compatible with all mongodb drivers and ODMs.

Features

  • 🔄 Provides an Object Oriented Programming (OOP) interface to the aggregation pipeline.
  • 🎯 Allows you to focus on your requirements rather than MongoDB syntax.
  • 📚 Integrates all the MongoDB documentation and allows you to quickly refer to it without having to navigate to the website.
  • 🔍 Enables autocompletion on the various MongoDB features.
  • 🔗 Offers a pandas-style way to chain operations on data.
  • 💻 Mimics the syntax of your favorite tools like pandas

📥 Installation

💡 The package is available on PyPI:

pip install monggregate

🚀 Usage

📘 The below examples reference the MongoDB sample_mflix database

🔰 Basic Pipeline usage

import os

from dotenv import load_dotenv 
import pymongo
from monggregate import Pipeline, S

# Creating connexion string securely
# You need to create a .env file with your password
load_dotenv(verbose=True)
MONGODB_URI = os.environ["MONGODB_URI"] 


# Connect to your MongoDB cluster:
client = pymongo.MongoClient(MONGODB_URI)

# Get a reference to the "sample_mflix" database:
db = client["sample_mflix"]

# Creating the pipeline
pipeline = Pipeline()

# The below pipeline will return the most recent movie with the title "A Star is Born"
pipeline.match(
    title="A Star Is Born"
).sort(
    by="year"
).limit(
    value=1
)

# Executing the pipeline
curosr = db["movies"].aggregate(pipeline.export())

# Printing the results
results = list(curosr)
print(results)

🌟 Advanced Usage, with MongoDB Operators

import os

from dotenv import load_dotenv 
import pymongo
from monggregate import Pipeline, S


# Creating connexion string securely
load_dotenv(verbose=True)
MONGODB_URI = os.environ["MONGODB_URI"]

# Connect to your MongoDB cluster:
client = pymongo.MongoClient(MONGODB_URI)

# Get a reference to the "sample_mflix" database:
db = client["sample_mflix"]


# Creating the pipeline
pipeline = Pipeline()
pipeline.match(
    year=S.type_("number") # Filtering out documents where the year field is not a number
).group(
    by="year",
    query = {
        "movie_count":S.sum(1), # Aggregating the movies per year
        "movie_titles":S.push("$title")
    }
).sort(
    by="_id",
    descending=True
).limit(10)

# Executing the pipeline
cursor = db["movies"].aggregate(pipeline.export())

# Printing the results
results = list(cursor)
print(results)

🔥 Even More Advanced Usage with Expressions

import os

from dotenv import load_dotenv 
import pymongo
from monggregate import Pipeline, S

# Creating connexion string securely
load_dotenv(verbose=True)
MONGODB_URI = os.environ["MONGODB_URI"] 

# Connect to your MongoDB cluster:
client = pymongo.MongoClient(MONGODB_URI)

# Get a reference to the "sample_mflix" database:
db = client["sample_mflix"]

# Using expressions
comments_count = S.size(S.comments)

# Creating the pipeline
pipeline = Pipeline()
pipeline.lookup(
    right="comments",
    right_on="movie_id",
    left_on="_id",
    name="comments"
).add_fields(
    comments_count=comments_count
).match(
    expression=comments_count>2
).limit(1)

# Executing the pipeline
cursor = db["movies"].aggregate(pipeline.export())

# Printing the results
results = list(cursor)
print(results)

🔍 Going Further

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

monggregate-0.22.1.tar.gz (97.9 kB view details)

Uploaded Source

Built Distribution

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

monggregate-0.22.1-py3-none-any.whl (169.1 kB view details)

Uploaded Python 3

File details

Details for the file monggregate-0.22.1.tar.gz.

File metadata

  • Download URL: monggregate-0.22.1.tar.gz
  • Upload date:
  • Size: 97.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.17

File hashes

Hashes for monggregate-0.22.1.tar.gz
Algorithm Hash digest
SHA256 6c36b5cea8ec51bd4a36e25f149d6f4b424060b9a8e023ef909884ae500b8c3a
MD5 f04130952201b30949117c9ecbb584b3
BLAKE2b-256 e28c9627d0d3a569a2e1c6657dcd27ff7593c33f07efc5c6d206c7bf27b58c78

See more details on using hashes here.

File details

Details for the file monggregate-0.22.1-py3-none-any.whl.

File metadata

File hashes

Hashes for monggregate-0.22.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4eef7839109ce4b1bb1172b6643fa22e2dc284a45e645ea55fd4efd848aedfb2
MD5 3c40c41c96a1692dd5b80b604c781d61
BLAKE2b-256 38772f37358731fdf228379fb9bdc0c736371691c0493075c393ee431e42b908

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