PyMongo安裝和使用
這里是簡單的安裝和使用記錄,首先要有一個可用的mongo環境,win環境或者linux環境都可以。 假定你對mongo有所了解和知道一些命令行操作。
安裝和更新
跟大多數py包安裝一樣,可以源碼安裝,也可以使用pip或者easy_install來安裝
-
安裝
pip install pymongo
</li> -
升級
pip install --upgrade pymongo
</li> -
其他安裝方法請參照文檔pymongo安裝
</li> </ul>操作
小案例
#-- coding: utf-8 --
python2.7x
author: orangleliu @2014-09-24
''' pymongo的簡單使用 '''
from pymongo import MongoClient
def get_db():
#建立連接 client = MongoClient("localhost", 27017) #test,還有其他寫法 db = client.test return db
def get_collection(db):
#選擇集合(mongo中collection和database都是lazy創建的,具體可以google下) collection = db['posts'] print collection
def insert_one_doc(db):
#插入一個document posts = db.posts post = {"name":"lzz", "age":25, "weight":"55"} post_id = posts.insert(post) print post_id
def insert_mulit_docs(db):
#批量插入documents,插入一個數組 posts = db.posts post = [ {"name":"nine", "age":28, "weight":"55"}, {"name":"jack", "age":25, "weight":"55"}] obj_ids = posts.insert(post) print obj_ids
查詢,可以對整個集合查詢,可以根ObjectId查詢,可以根據某個字段查詢等
def get_all_colls(db):
#獲得一個數據庫中的所有集合名稱 print db.collection_names()
def get_one_doc(db):
#有就返回一個,沒有就返回None posts = db.posts print posts.find_one() print posts.find_one({"name":"jack"}) print posts.find_one({"name":"None"}) return
def get_one_by_id(db):
#通過objectid來查找一個doc posts = db.posts obj = posts.find_one() obj_id = obj["_id"] print "_id 為ObjectId類型 :" print posts.find_one({"_id":obj_id}) #需要注意這里的obj_id是一個對象,不是一個str,使用str類型作為_id的值無法找到記錄 print "_id 為str類型 " print posts.find_one({"_id":str(obj_id)}) #可以通過ObjectId方法把str轉成ObjectId類型 from bson.objectid import ObjectId print "_id 轉換成ObjectId類型" print posts.find_one({"_id":ObjectId(str(obj_id))})
def get_many_docs(db):
#mongo中提供了過濾查找的方法,可以通過各 #種條件篩選來獲取數據集,還可以對數據進行計數,排序等處理 posts = db.posts #所有數據,按年齡排序, -1是倒序 all = posts.find().sort("age", -1) count = posts.count() print "集合中所有數據 %s個"%int(count) for i in all: print i #條件查詢 count = posts.find({"name":"lzz"}).count() print "lzz: %s"%count for i in posts.find({"name":"lzz", "age":{"$lt":20}}): print i
def clear_coll_datas(db):
#清空一個集合中的所有數據 db.posts.remove({})
if name == "main": db = get_db() obj_id = insert_one_doc(db) obj_ids = insert_mulit_docs(db)
#get_all_colls(db) #get_one_doc(db) #get_one_by_id(db) #get_many_docs(db) clear_coll_datas(db)</code></pre></div>
這都是寫簡單的操作,至于集合操作,group操作等以后在總結。
</div> 來自:http://blog.csdn.net/orangleliu/article/details/39545751本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!