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

Uploaded Source

Built Distribution

mongodb_backup_exporter-0.3.13-py3-none-any.whl (6.9 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for mongodb-backup-exporter-0.3.13.tar.gz
Algorithm Hash digest
SHA256 06cc4d2eec023a014d37740f9db825a54ea817d2b3c405fb596f2ac26054ca9d
MD5 44cf9fec91c7bf4ac884e565627598d0
BLAKE2b-256 8631fbad5033b99beb79934f411c438960aeac4bf88c91d670fc026d732db46a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for mongodb_backup_exporter-0.3.13-py3-none-any.whl
Algorithm Hash digest
SHA256 306bde2e41abad5a2e4a6614d27a10758fa1147be20b78a3e0d60f3dbb914a2b
MD5 b401a5194af1442ab3292ad665507ed2
BLAKE2b-256 a5cbd4a1a5d9fdb344e6f9ec0f2a68cdfce97d657dfdf8250d9612e013dbd0e3

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