[Mongo]PyMongo安裝和使用

PyMongo安裝和使用

這裏是簡單的安裝和使用記錄,首先要有一個可用的mongo環境,win環境或者linux環境均可以。 假定你對mongo有所瞭解和知道一些命令行操做。html

安裝和更新

跟大多數py包安裝同樣,能夠源碼安裝,也能夠使用pip或者easy_install來安裝python

  • 安裝linux

    pip install pymongomongodb

  • 升級數據庫

    pip install --upgrade pymongoapi

  • 其餘安裝方法請參照文檔pymongo安裝數組

操做

官網教程python2.7

小案例

#-*- 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)

這都是寫簡單的操做,至於集合操做,group操做等之後在總結。post

本文出自 「orangleliu筆記本」 博客,請務必保留此出處 http://blog.csdn.net/orangleliu/article/details/39545751
相關文章
相關標籤/搜索