Skip to content

Instantly share code, notes, and snippets.

@kenju254
Forked from 0m15/mongo_chunk.py
Created December 13, 2015 13:31
Show Gist options
  • Star 7 You must be signed in to star a gist
  • Fork 3 You must be signed in to fork a gist
  • Save kenju254/401c251b5fbb97e6127b to your computer and use it in GitHub Desktop.
Save kenju254/401c251b5fbb97e6127b to your computer and use it in GitHub Desktop.
Python script that can export Mongo collections of any size into progressive numbered json chunks, type `python mongo_chunk.py --help` to have a list of available options
#!/usr/bin/python
import argparse
from pymongo import MongoClient as Client
from bson import BSON
from bson import json_util
import json
import os
# mongo client
client = Client()
# script arguments
parser = argparse.ArgumentParser(description='Export a Mongo Collection into json chunks given an offset')
parser.add_argument('--db', metavar='d', type=str, help='specify a mongo db', dest='db')
parser.add_argument('--collection', metavar='c', type=str, help='specify a mongo collection', dest='collection')
parser.add_argument('--offset', metavar='O', type=int, help='specify an offset (default=1000)', dest='offset')
parser.add_argument('--prefix', metavar='o', type=str, help='specify an output prefix', dest='prefix')
parser.add_argument('--dir', metavar='D', type=str, help='specify an existing directory', dest='directory', default='')
args = parser.parse_args()
# variables
db = client[args.db]
collection = db[args.collection]
offset = args.offset
prefix = args.prefix
print 'Selected database: {}'.format(db)
print 'Selected collection: {}'.format(collection)
print 'Offset: {}'.format(offset)
last_offset = 0
def json_chunks(offset):
offset = offset
total_docs = collection.find().count()
if total_docs < offset:
print '! Error: offset is greater than number of total documents'
exit()
chunks = total_docs / offset
chunk_idx = 0
for i in range(0, total_docs + offset, offset):
if i >= total_docs:
print 'export successfully finished'
exit()
dump = None
docs = None
json_file_path = os.path.join('{}'.format(args.directory), '{}_chunk__{}.json'.format(args.prefix, chunk_idx))
print 'i: {}'.format(i)
print 'offset: {}'.format(i + offset)
print 'query: collection.find().skip({}).limit({})'.format(i, offset)
if i + offset > total_docs:
offset_diff = offset - total_docs
offset = offset - offset_diff
docs = collection.find().skip(i).limit(offset)
with open(json_file_path, 'w') as outfile:
dump = json.dumps([doc for doc in docs], sort_keys=False, indent=4, default=json_util.default)
outfile.write(dump)
chunk_idx += 1
print 'export successfully finished'
json_chunks(offset)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment