Skip to main content

A tool to export MongoDB collections to JSON or CSV files

Project description

MongoDB Backup Exporter

A utility for exporting MongoDB collections to JSON or CSV format.

Publish MongoDB Backup Collections Exporter Python Package

Features

  • Export collections from MongoDB to JSON or CSV format.
  • Automatically handles output directories.
  • Supports exporting all collections or specified ones.
  • Provides stats about each collection before exporting.
  • Supports pretty-printing of JSON output and exporting JSON in list format.

Installation PyPI

You can install mongodb-backup-exporter directly from PyPI using pip:

pip install mongodb-backup-exporter

Installation Using Repository

  1. Clone the repository:

    git clone https://github.com/jorgecardona/mongodb-backup-exporter.git
    cd mongodb-backup-exporter
    
  2. Install required Python packages:

    Create a virtual environment (optional but recommended):

    python -m venv venv
    source venv/bin/activate  # On Windows use: venv\Scripts\activate
    

    Then, install the required packages:

    pip install -r requirements.txt
    
  3. Install mongoexport from MongoDB Command Line Database Tools Download:

    • Windows: Download the MongoDB Database Tools from the MongoDB official site. After installation, ensure that the mongoexport executable is in your system's PATH.

    • Linux: You can install the MongoDB Database Tools using the package manager for your distribution. For example, on Ubuntu, you can do:

    Validate Linux Version

    uname -a
    
    cat /etc/os-release
    

    linux_version

    Install mongodb-database-tools

    curl -O https://fastdl.mongodb.org/tools/db/mongodb-database-tools-debian12-x86_64-100.10.0.tgz && \
     tar -xvzf mongodb-database-tools-debian12-x86_64-100.10.0.tgz && \
     cd mongodb-database-tools-debian12-x86_64-100.10.0 && \
     sudo cp -r bin/* /usr/local/bin/ && \
     cd .. && \
     rm -rf mongodb-database-tools-debian12-x86_64-100.10.0 && \
     rm mongodb-database-tools-debian12-x86_64-100.10.0.tgz
    

    Verify the version of MongoDB Database Tools

    mongoexport --version
    

    Check the installation directory for MongoDB Database Tools

    which mongoexport
    

    install_mongodb-database-tools

    Alternatively, you can download the tools from the MongoDB official site.

Usage

To use the MongoDBBackupExporter, you can instantiate it in your script:

from mongodb_backup_exporter import MongoDBBackupExporter

# Configuration for MongoDB connection
username = "your_username"  # MongoDB username
password = "your_password"  # MongoDB password
hostname = "your_cluster.mongodb.net"  # MongoDB cluster address
db_name = "your_database_name"  # Database name
mongoexport_path = "path/to/mongoexport"  # Path to mongoexport executable

# Create an instance of MongoDBBackupExporter
exporter = MongoDBBackupExporter(
    username=username,  # The username for the MongoDB database
    password=password,  # The password for the MongoDB database
    hostname=hostname,  # The cluster address for the MongoDB connection
    db_name=db_name,  # The name of the database to be backed up
    mongoexport_path=mongoexport_path,  # Path to the mongoexport executable
    output_format='json',  # Specifies the format for the exported files; can be 'json' or 'csv'
    json_list=True,  # If True, each JSON object will be written on a new line in list format
    pretty_json=True,  # If True, the JSON output will be formatted for better readability
    output_dir='output_directory_path',  # Directory where output files will be saved; defaults to current working directory if None
    collections_to_export=['collection1', 'collection2'],  # Specify collections to export; if None, all collections will be exported
)

# Execute the export process
# This method will export the specified collections from the MongoDB database
# to the designated output directory in the specified format.
exporter.execute_export()

Requirements

  • Python 3.6 or higher
  • pymongo library (install via pip install pymongo)
  • mongoexport must be installed and accessible in your system's PATH.

Extracts to Json

mongo_db_json

Extracts to CSV

mongo_db_csv

Extracts to Json List

mongo_db_json_list

Extracts to Json Pretty

mongo_db_json_pretty

Restore Collection Using Json file

mongodb_restore_1 mongodb_restore_2 mongodb_restore_3 mongodb_restore_4

License

This project is licensed under the MIT License. See the LICENSE file for details.

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

mongodb-backup-exporter-0.3.131.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file mongodb-backup-exporter-0.3.131.tar.gz.

File metadata

File hashes

Hashes for mongodb-backup-exporter-0.3.131.tar.gz
Algorithm Hash digest
SHA256 e569a4c01758c9b89611df34ce9976eb4096ad174cc1b7ea743335ce235d2261
MD5 59124dd94af5243a1cca39b6c95aae63
BLAKE2b-256 e8d7e935dae49dde642da3ad76ccaeac51969b641c53e4c545640d98a74d78ef

See more details on using hashes here.

File details

Details for the file mongodb_backup_exporter-0.3.131-py3-none-any.whl.

File metadata

File hashes

Hashes for mongodb_backup_exporter-0.3.131-py3-none-any.whl
Algorithm Hash digest
SHA256 352656148e3c0e48fe2ce05d9f32c295eac9e12afdfca5e326d6fed4e79825a1
MD5 41c1f774f06247d5b5f226872b1410d5
BLAKE2b-256 f752fe6d039524e38a898f1ab671409bd6ebf3c8f3510373741bb80b533d4e1d

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