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.213.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

File details

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

File metadata

File hashes

Hashes for mongodb-backup-exporter-0.3.213.tar.gz
Algorithm Hash digest
SHA256 7ab709fe2bcd0cb1abc1f02f2a0c00dfb4e232a764d65adcee99348ecf78f2ad
MD5 869941ecab2df5e8a8b525249cc33454
BLAKE2b-256 b57fe2007e559e82894fa6d590b7c8607b749c22046d770a5c2f5969aa4e9398

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for mongodb_backup_exporter-0.3.213-py3-none-any.whl
Algorithm Hash digest
SHA256 12efb1ce329de8525aa6efbf5f0e7083cc0f0837b3160007d3709296bd6918a6
MD5 73745751bc6b0736deffa34413eafa16
BLAKE2b-256 defd685422d573c5f41c98b3c205c5362a02ba2a1cda317b81fb065145018812

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