吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1630|回复: 5
收起左侧

[Python 转载] mongo全量导出并保存成json格式数据

  [复制链接]
lideshan 发表于 2022-6-2 14:03
import json
import os

import pymongo

# 连接数据库
client = pymongo.MongoClient('localhost', 27017)
# 数据库保存文件夹
db_path = './data_back'
# 获取所有mongoDB的数据库名称
db_list = client.list_database_names()
# 去除数据库名称列表中的system数据库
admin_list = ['admin', 'local', 'config']
db_list = [db for db in db_list if db not in admin_list]  # 去除数据库名称中无关的数据库
# 循环遍历数据库名称保存数据到json中
for db_name in db_list:
    # 连接数据库
    db = client[db_name]
    # 获取数据库中所有的集合名称
    collection_list = db.list_collection_names()
    # 去除集合名称列表中的system数据库
    collection_list = [collection for collection in collection_list if collection not in admin_list]
    # 循环遍历集合名称保存数据到json中
    for collection_name in collection_list:
        # 连接集合
        collection = db[collection_name]
        # 获取集合中所有的文档
        # with 上下文进行管理,设置no_cursor_timeout=True参数,让游标不会超时,防止程序阻塞
        with collection.find({}, {"_id": 0}, no_cursor_timeout=True) as cursor:
            # 循环遍历文档保存数据到json中
            for row in cursor:
                # 创建文件夹
                if not os.path.exists(db_path):
                    os.makedirs(db_path)
                # 创建文件
                with open(os.path.join(db_path, db_name + '_' + collection_name + '.json'), 'a') as f:
                    # 将文档写入文件
                    f.write(json.dumps(row, ensure_ascii=False) + '\n')

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

fxyc87 发表于 2022-6-2 15:18
这个数据库全称叫MongoDB,你直接来个Mongo,看的不知所措。
文人墨客 发表于 2022-6-2 15:53
thisxx 发表于 2022-6-2 17:29
fxyc87 发表于 2022-6-2 15:18
这个数据库全称叫MongoDB,你直接来个Mongo,看的不知所措。

生产一般简称mongo的
XiaoZouYu 发表于 2022-6-2 19:24
fxyc87 发表于 2022-6-2 15:18
这个数据库全称叫MongoDB,你直接来个Mongo,看的不知所措。

不会吧,叫mongo没毛病呀
 楼主| lideshan 发表于 2022-6-7 15:03
fxyc87 发表于 2022-6-2 15:18
这个数据库全称叫MongoDB,你直接来个Mongo,看的不知所措。

不好意思,习惯叫mongo了
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 05:43

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表