web-dev-qa-db-fra.com

Comment importer un fichier Json dans MongoDB en utilisant Python

J'ai ce fichier JSON, currencies.json:

{
    "AUD": 1.5978,
    "BGN": 1.9558,
    "BRL": 4.0726,
    "CAD": 1.5868,
    "CHF": 1.1703,
    "CNY": 7.7975,
    "CZK": 25.405,
    "DKK": 7.4478,
    "GBP": 0.87285,
    "HKD": 9.6889,
    "HRK": 7.4398,
    "HUF": 312.9,
    "IDR": 16993.0,
    "ILS": 4.2984,
    "INR": 80.255,
    "ISK": 122.1,
    "JPY": 129.74,
    "KRW": 1330.3,
    "MXN": 22.88,
    "MYR": 4.8365,
    "NOK": 9.5715,
    "NZD": 1.7024,
    "PHP": 64.64,
    "PLN": 4.2262,
    "RON": 4.663,
    "RUB": 70.539,
    "SEK": 10.194,
    "SGD": 1.6216,
    "THB": 38.495,
    "TRY": 4.888,
    "USD": 1.2346,
    "ZAR": 14.52
}

Et cette connexion en Python:

from pymongo import MongoClient
client = MongoClient ('localhost', 27017)
db = client['countries_db']
collection_currency = db['currency']

Mon nom de base de données est countries_db avec la collection currency. Existe-t-il un moyen d'importer le fichier dans la base de données en utilisant python? Merci de votre aide.

8
Filipe Varandas

Vous pouvez lire les données du fichier et les insérer dans la collection en utilisant la méthode insert_one :

import json
from pymongo import MongoClient


client = MongoClient('localhost', 27017)
db = client['countries_db']
collection_currency = db['currency']

with open('currencies.json') as f:
    file_data = json.load(f)

# use collection_currency.insert(file_data) if pymongo version < 3.0
collection_currency.insert_one(file_data)  
client.close()
11
Ivan Vinogradov