PyMongo安装使用笔记
这里是简单的安装和使用记录,首先要有一个可用的mongo环境,win环境或者linux环境都可以。假定你对mongo有所了解和知道一些命令行操作。
安装和更新
跟大多数py包安装一样,可以源码安装,也可以使用pip或者easy_install来安装
安装
pipinstallpymongo
升级
pipinstall--upgradepymongo
其他安装方法请参照文档pymongo安装
操作
官网教程
小案例
#-*-coding:utf-8-*- #python2.7x #author:orangleliu @2014-09-24 ''' pymongo的简单使用 '''
frompymongoimportMongoClient
defget_db(): #建立连接 client=MongoClient("localhost",27017) #test,还有其他写法 db=client.test returndb
defget_collection(db): #选择集合(mongo中collection和database都是lazy创建的,具体可以google下) collection=db['posts'] printcollection
definsert_one_doc(db): #插入一个document posts=db.posts post={"name":"lzz","age":25,"weight":"55"} post_id=posts.insert(post) printpost_id
definsert_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) printobj_ids
##查询,可以对整个集合查询,可以根ObjectId查询,可以根据某个字段查询等 defget_all_colls(db): #获得一个数据库中的所有集合名称 printdb.collection_names()
defget_one_doc(db): #有就返回一个,没有就返回None posts=db.posts printposts.find_one() printposts.find_one({"name":"jack"}) printposts.find_one({"name":"None"}) return
defget_one_by_id(db): #通过objectid来查找一个doc posts=db.posts obj=posts.find_one() obj_id=obj["_id"] print"_id为ObjectId类型:" printposts.find_one({"_id":obj_id}) #需要注意这里的obj_id是一个对象,不是一个str,使用str类型作为_id的值无法找到记录 print"_id为str类型" printposts.find_one({"_id":str(obj_id)})
#可以通过ObjectId方法把str转成ObjectId类型 frombson.objectidimportObjectId print"_id转换成ObjectId类型" printposts.find_one({"_id":ObjectId(str(obj_id))})
defget_many_docs(db): #mongo中提供了过滤查找的方法,可以通过各 #种条件筛选来获取数据集,还可以对数据进行计数,排序等处理 posts=db.posts #所有数据,按年龄排序,-1是倒序 all= posts.find().sort("age",-1)
count=posts.count() print"集合中所有数据%s个"%int(count) foriinall: printi
#条件查询 count=posts.find({"name":"lzz"}).count() print"lzz:%s"%count foriin posts.find({"name":"lzz","age":{"$lt":20}}): printi
defclear_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)