mongodb — просмотреть коллекцию в виде таблицы

Я новичок в Mongodb, и я пытаюсь понять это. Это не обычная СУБД. Итак, я создал коллекции, используя приведенный ниже оператор

db.inventory.insertMany([
   { item: "journal", qty: 25, size: { h: 14, w: 21, uom: "cm" }, status: "A" },
   { item: "notebook", qty: 50, size: { h: 8.5, w: 11, uom: "in" }, status: "A" },
   { item: "paper", qty: 100, size: { h: 8.5, w: 11, uom: "in" }, status: "D" },
   { item: "planner", qty: 75, size: { h: 22.85, w: 30, uom: "cm" }, status: "D" },
   { item: "postcard", qty: 45, size: { h: 10, w: 15.25, uom: "cm" }, status: "A" }
]);

Теперь, если я хочу увидеть данные в коллекции "inventory", я использовал запрос ниже.

db.inventory.find()

Я могу видеть данные, но это слишком неуклюже. Есть ли способ просмотреть данные в виде таблицы? Как в СУБД? если не в скорлупе? есть ли библиотека python для улучшения внешнего вида таблицы.


person Sandhya Thotakura    schedule 11.02.2019    source источник
comment
Используйте метод курсора .pretty()   -  person Ashh    schedule 11.02.2019


Ответы (3)


Да, это можно просмотреть в формате таблицы, все, что вам нужно, это использовать пакет pandas для python.

import pandas as pd

inventory_data = [data for data in db.inventory.find()]
df_inventory_data = pd.DataFrame(inventory_data)
print(df_inventory_data)
person Souvik Daw    schedule 20.08.2019

Pandas — это путь к Python, как отметил другой участник.

Если вы хотите просмотреть данные в более «традиционном» формате, используйте такой инструмент, как MongoDB Compass, Studio 3T или Nosqlclient.

Что касается «неуклюжих» данных, если вы хотите хорошо работать с mongodb, вам нужно будет привыкнуть к формату JSON. Используйте db.inventory.findOne() или db.inventory.find().pretty(), чтобы украсить вывод.

person Belly Buster    schedule 20.08.2019

Если вы используете такой инструмент, как Robot-3t. Вы можете установить режим просмотра по умолчанию на «Режим таблицы».

введите здесь описание изображения

person Pratik Khadloya    schedule 24.12.2019