一.使用
通過pip或者pychrm下載pymongo模塊
import json from pymongo import MongoClient from bson import ObjectId mc = MongoClient("127.0.0.1",27017) MONGODB = mc["數據庫名"] MONGODB.users.find({}) # 可以操作了
上面的文件一般單獨寫一個settings.py,在用到的時候,通過引入MONGO來操作
關於bson:
mongo中取出的數據有一個'_id'字段相當於mysql中的id, 這個字段的類型是Objectid,所以查詢的結果不能直接json序列化,需要將這個'_id'轉化為str類型后才能json序列化,相應的,從前端傳過來的'_id'也要通過bson轉化為ObjectId才能查到Mongodb中的數據
@au.route('/auto_login',methods=['POST']) def auto_login(): user_info = request.form.to_dict() print(user_info) try: user_id = user_info.get('user_id') user = MONGODB.users.find_one({'_id': ObjectId(user_id)}) user['_id'] = str(user['_id']) RET = { 'code': 1, 'msg': '自動登陸成功', 'data': user } except: RET = { 'code': 0, 'msg': '自動登陸失敗', 'data': {} } return jsonify(RET)
操作示例
# MONGODB = mc["admin"] # res = MONGODB.users.find_one({"name":"Tom"}) # res["cours"].append({"name":"Tom","money":"100"}) # for index,cours in enumerate(res["cours"]): # if cours.get("name") == "Tom": # res["cours"][index]["score"] = 99 # MONGODB.users.delete_one({"age":84}) # MONGODB.users.delete_many({"age":84}) # user = MONGODB.users.find_one({"_id":ObjectId("5cb6eb7322b9441020186701")}) # print(user.get("_id"),type(user.get("_id"))) # # user["_id"] = str(user["_id"]) # jsonstr = json.dumps(user) # print(jsonstr , type(jsonstr))