Получить имя базы данных из объекта PyMongo - PullRequest
0 голосов
/ 27 сентября 2018

В настоящее время я работаю над проектом колбы, который использует несколько чертежей и монго для хранения данных.Я создал несколько экземпляров PyMongo для доступа к различным базам данных:

В app.py, который является основным файлом проекта, я определил экземпляры:

# The PyMongo instance 'mongo_app' takes its uri from the project's config.
mongo_app.init_app(app)

# The second PyMongo instance is initialized with the needed uri.
mongo_project.init_app(app, uri="mongodb://mongodb:27017/rick_and_morty")

В проектеДля проекта мне нужно имя базы данных, с которой был инициализирован объект PyMongo «mongo_project», а именно «rick_and_morty».

Мой вопрос: как я могу высосать эту информацию из объекта PyMongo?Я пытаюсь достичь чего-то вроде следующего:

database_name = mongo_project.db_name #rick_and_morty

Ответы [ 2 ]

0 голосов
/ 27 сентября 2018

Также вы можете использовать uri_parser от pymongo: http://api.mongodb.com/python/current/api/pymongo/uri_parser.html

Python 2.7.13 (default, Jun  9 2017, 18:24:27) 
[GCC 4.4.7 20120313 (Red Hat 4.4.7-17)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import pymongo
>>> parsed=pymongo.uri_parser.parse_uri('mongodb://mongodb:27017/rick_and_morty')
>>> print parsed['database']
rick_and_morty
0 голосов
/ 27 сентября 2018

Присоедините их к приложению Flask и получите доступ с помощью current_app

# app.py
from collections import namedtuple
from flask import Flask
from my_blueprint import app_blueprint

app = Flask(__name__)
app.mongo_project = namedtuple("whatever", ["db_name"])(db_name="db_name_1")
app.register_blueprint(app_blueprint)

# my_blueprint.py
from flask import Blueprint, current_app

app_blueprint = Blueprint('app_blueprint', __name__)

@app_blueprint.route("/blueprint_route")
def foobar():
    database_name = current_app.mongo_project.db_name
    return database_name
...