[Mongo]PyMongo安装和使用

来源:互联网 发布:mysql数据库文件扩展名 编辑:程序博客网 时间:2024/05/22 20:56

PyMongo安装和使用

这里是简单的安装和使用记录,首先要有一个可用的mongo环境,win环境或者linux环境都可以。 假定你对mongo有所了解和知道一些命令行操作。

安装和更新

跟大多数py包安装一样,可以源码安装,也可以使用pip或者easy_install来安装

  • 安装

    pip install pymongo

  • 升级

    pip install --upgrade pymongo

  • 其他安装方法请参照文档pymongo安装

操作

官网教程

小案例

#-*- coding: utf-8 -*-#python2.7x#author: orangleliu  @2014-09-24'''pymongo的简单使用'''from pymongo import MongoClientdef get_db():    #建立连接    client = MongoClient("localhost", 27017)    #test,还有其他写法    db = client.test    return dbdef get_collection(db):    #选择集合(mongo中collection和database都是lazy创建的,具体可以google下)    collection = db['posts']    print collectiondef insert_one_doc(db):    #插入一个document    posts = db.posts    post = {"name":"lzz", "age":25, "weight":"55"}    post_id = posts.insert(post)    print post_iddef 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"})    returndef 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 idef 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操作等以后在总结。

本文出自 “orangleliu笔记本” 博客,请务必保留此出处 http://blog.csdn.net/orangleliu/article/details/39545751
1 0
原创粉丝点击