欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PyMongo安裝使用筆記

 更新時(shí)間:2015年04月27日 11:30:52   投稿:junjie  
這篇文章主要介紹了PyMongo安裝使用筆記,本文講解使用pip方式安裝PyMongo,并給出一個(gè)pymongo的簡(jiǎn)單使用代碼實(shí)例,需要的朋友可以參考下

這里是簡(jiǎn)單的安裝和使用記錄,首先要有一個(gè)可用的mongo環(huán)境,win環(huán)境或者linux環(huán)境都可以。 假定你對(duì)mongo有所了解和知道一些命令行操作。

安裝和更新
跟大多數(shù)py包安裝一樣,可以源碼安裝,也可以使用pip或者easy_install來(lái)安裝

安裝

復(fù)制代碼 代碼如下:

pip install pymongo

升級(jí)
復(fù)制代碼 代碼如下:

pip install --upgrade pymongo

其他安裝方法請(qǐng)參照文檔pymongo安裝

操作

官網(wǎng)教程

小案例

復(fù)制代碼 代碼如下:

#-*- coding: utf-8 -*-
#python2.7x
#author: orangleliu  @2014-09-24
'''
pymongo的簡(jiǎn)單使用
'''

from pymongo import MongoClient

def get_db():
    #建立連接
    client = MongoClient("localhost", 27017)
    #test,還有其他寫(xiě)法
    db = client.test
    return db

def get_collection(db):
    #選擇集合(mongo中collection和database都是lazy創(chuàng)建的,具體可以google下)
    collection = db['posts']
    print collection

def insert_one_doc(db):
    #插入一個(gè)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,插入一個(gè)數(shù)組
    posts = db.posts
    post = [ {"name":"nine", "age":28, "weight":"55"},
                 {"name":"jack", "age":25, "weight":"55"}]
    obj_ids = posts.insert(post)
    print obj_ids

##查詢,可以對(duì)整個(gè)集合查詢,可以根ObjectId查詢,可以根據(jù)某個(gè)字段查詢等
def get_all_colls(db):
    #獲得一個(gè)數(shù)據(jù)庫(kù)中的所有集合名稱
    print db.collection_names()

def get_one_doc(db):
    #有就返回一個(gè),沒(méi)有就返回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):
    #通過(guò)objectid來(lái)查找一個(gè)doc
    posts = db.posts
    obj = posts.find_one()
    obj_id = obj["_id"]
    print "_id 為ObjectId類型 :"
    print posts.find_one({"_id":obj_id})
    #需要注意這里的obj_id是一個(gè)對(duì)象,不是一個(gè)str,使用str類型作為_(kāi)id的值無(wú)法找到記錄
    print "_id 為str類型 "
    print posts.find_one({"_id":str(obj_id)})

    #可以通過(guò)ObjectId方法把str轉(zhuǎn)成ObjectId類型
    from bson.objectid import ObjectId
    print "_id 轉(zhuǎn)換成ObjectId類型"
    print posts.find_one({"_id":ObjectId(str(obj_id))})

def get_many_docs(db):
    #mongo中提供了過(guò)濾查找的方法,可以通過(guò)各
    #種條件篩選來(lái)獲取數(shù)據(jù)集,還可以對(duì)數(shù)據(jù)進(jìn)行計(jì)數(shù),排序等處理
    posts = db.posts
    #所有數(shù)據(jù),按年齡排序, -1是倒序
    all =  posts.find().sort("age", -1)

    count = posts.count()
    print "集合中所有數(shù)據(jù) %s個(gè)"%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):
    #清空一個(gè)集合中的所有數(shù)據(jù)
    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)


這都是寫(xiě)簡(jiǎn)單的操作,至于集合操作,group操作等以后在總結(jié)。

相關(guān)文章

  • Python實(shí)現(xiàn)獲取視頻時(shí)長(zhǎng)功能

    Python實(shí)現(xiàn)獲取視頻時(shí)長(zhǎng)功能

    這篇文章主要介紹了Python如何實(shí)現(xiàn)獲取視頻時(shí)長(zhǎng)功能,可以精確到毫秒。文中的示例代碼簡(jiǎn)潔易懂,對(duì)我們的學(xué)習(xí)有一定的幫助,感興趣的可以了解一下
    2021-12-12
  • Python 解析庫(kù)json及jsonpath pickle的實(shí)現(xiàn)

    Python 解析庫(kù)json及jsonpath pickle的實(shí)現(xiàn)

    這篇文章主要介紹了Python 解析庫(kù)json及jsonpath pickle的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • python3 反射的四種基本方法解析

    python3 反射的四種基本方法解析

    這篇文章主要介紹了python3 反射的四種基本方法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • 如何使用Python代碼創(chuàng)建表格

    如何使用Python代碼創(chuàng)建表格

    如果能夠?qū)⑽覀兊臒o(wú)序數(shù)據(jù)快速組織成更易讀的格式,對(duì)于數(shù)據(jù)分析非常有幫助,下面這篇文章主要介紹了關(guān)于如何使用Python代碼創(chuàng)建表格的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • python基礎(chǔ)之while循環(huán)語(yǔ)句的使用

    python基礎(chǔ)之while循環(huán)語(yǔ)句的使用

    這篇文章主要介紹了python基礎(chǔ)之while循環(huán)語(yǔ)句的使用,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python的小伙伴們有一定的幫助,需要的朋友可以參考下
    2021-04-04
  • 深度學(xué)習(xí)環(huán)境搭建anaconda+pycharm+pytorch的方法步驟

    深度學(xué)習(xí)環(huán)境搭建anaconda+pycharm+pytorch的方法步驟

    本文主要介紹了深度學(xué)習(xí)環(huán)境搭建anaconda+pycharm+pytorch的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • python爬蟲(chóng) 線程池創(chuàng)建并獲取文件代碼實(shí)例

    python爬蟲(chóng) 線程池創(chuàng)建并獲取文件代碼實(shí)例

    這篇文章主要介紹了python爬蟲(chóng) 線程池創(chuàng)建并獲取文件代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • python切片操作方法的實(shí)例總結(jié)

    python切片操作方法的實(shí)例總結(jié)

    所謂切片就是在某個(gè)數(shù)據(jù)里提取需要的部分,提取到的是某個(gè)索引下的值,或者索引區(qū)間的值,下面這篇文章主要給大家介紹了關(guān)于python切片操作方法的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • python 實(shí)現(xiàn)的截屏工具

    python 實(shí)現(xiàn)的截屏工具

    這篇文章主要介紹了python 如何實(shí)現(xiàn)一個(gè)截屏工具,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下
    2021-05-05
  • Python3標(biāo)準(zhǔn)庫(kù)之dbm UNIX鍵-值數(shù)據(jù)庫(kù)問(wèn)題

    Python3標(biāo)準(zhǔn)庫(kù)之dbm UNIX鍵-值數(shù)據(jù)庫(kù)問(wèn)題

    dbm是面向DBM數(shù)據(jù)庫(kù)的一個(gè)前端,DBM數(shù)據(jù)庫(kù)使用簡(jiǎn)單的字符串值作為鍵來(lái)訪問(wèn)包含字符串的記錄。這篇文章主要介紹了Python3標(biāo)準(zhǔn)庫(kù):dbm UNIX鍵-值數(shù)據(jù)庫(kù)的相關(guān)知識(shí),需要的朋友可以參考下
    2020-03-03

最新評(píng)論