如何使用Python将Json文件导入MongoDB

Fil*_*das 8 python json mongodb

我有这个Json文件,currency.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
}
Run Code Online (Sandbox Code Playgroud)

}

而这在Python中的连接

from pymongo import MongoClient
client = MongoClient ('localhost', 27017)
db = client['countries_db']
collection_currency = db['currency']
Run Code Online (Sandbox Code Playgroud)

我的数据库名称是countries_db,带有货币集合.有没有办法使用python将文件导入数据库?谢谢你的帮助.

Iva*_*dov 11

您可以使用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()
Run Code Online (Sandbox Code Playgroud)

  • 如果你有一个大文件,你可能最好根据[这个问题](/sf/answers/1115888441/)使用`mongoimport`和python的`subprocess.run()` (2认同)