PyMongo安装使用笔记_python

这里是简单的安装和使用记录,首先要有一个可用的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 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操作等以后在总结。

时间: 2024-10-06 13:29:18

PyMongo安装使用笔记_python的相关文章

Oracle 9I安装使用笔记

oracle|笔记 Oracle 9I安装使用笔记author: Tansfdate: 2004-11-10 一.安装Oracle 9I 一共三张光碟1全局数据库名 : tan.eyesomdbSID: tan---需要手动输入 2 数据库文件目录C:\oracle\oradata 3 数据库信息全局数据库名 : tan.eyesomdbSID: tan全局数据库名 : tan.eyesomdbSID: tanSYS口令:change_on_install -- 改为: sys123456SYS

Python NumPy库安装使用笔记

  这篇文章主要介绍了Python NumPy库安装使用笔记,本文讲解了NumPy的安装和基础使用,并对每一句代码都做了详细解释,需要的朋友可以参考下 1. NumPy安装 使用pip包管理工具进行安装 代码如下: $ sudo pip install numpy 使用pip包管理工具安装ipython(交互式shell工具) 代码如下: $ sudo pip instlal ipython $ ipython --pylab #pylab模式下, 会自动导入SciPy, NumPy, Matp

Php-Redis安装测试笔记

 这篇文章主要介绍了Php-Redis安装测试笔记,本文讲解了redis安装.redis测试.安装phpredis扩展.测试php-redis等内容,需要的朋友可以参考下     后端开发用到php操作redis,在此将安装测试过程中遇到的问题汇总记录下来,以便以后参考!(系统为ubuntu) 1.redis安装 下载地址:http://download.redis.io/releases/ 解压安装: 代码如下: tar -xvf redis-2.8.17.tar.gz make sudo m

运行Node.js的IIS扩展iisnode安装配置笔记

 这篇文章主要介绍了运行Node.js的IIS扩展iisnode安装配置笔记,iisnode的扩展可以把Node.js程序托管到IIS,托管之后也意味着可以使用IIS里面的各种功能,需要的朋友可以参考下     今年年初打算用Node.js基于Express框架重写博客程序,从此告别ASP.NET.然而,我目前用的VPS是Windows Server系统.IIS服务器,如果让Express和IIS都监听80端口,明显会产生冲突.幸好,有一个叫做iisnode的扩展可以把Node.js程序托管到I

pymongo安装与模糊匹配查询

安装和更新 跟大多数py包安装一样,可以源码安装,也可以使用pip或者easy_install来安装 安装 pip install pymongo 升级 pip install --upgrade pymongo 其他安装方法请参照文档pymongo安装 记录mongo模糊匹配查询的实现方法: 在mongo中: {'filed':/value/} 使用pymongo,有以下两种方式: import re {'xxx':re.compile('xxx')} {'xxx':{'$regex':'xx

pymongo安装

1. sudo apt-get install build-essential python-dev 2. python   3. 输入:     import pymongo   4. 如果没有错误     那么pymongo安装成功    

Nginx + PHP(FastCGI)安装配置笔记

这是站长在2011年时一次安装服务器时所记录的Nginx和PHP的安装笔记.安装过程记录的比较简略,仅仅是一个大致的流程,一些细节描述的不够详细,请多多谅解,我会在日后重新整理一份详细的安装过程,本文仅供参考! 软件环境:CentOS 5.7 + PHP 5.2.17 + Nginx 0.8.55   1. 编译安装 PHP 和 PHP-FPM 提示: 安装PHP前应先安装MySQL,具体方法请自行baidu或google: PHP所需支持库的安装这里不做过多介绍,可上网搜索参照相关教程进行安装

centos 6.4系统中mongodb安装配置笔记

一.MongoDb是什么 MongoDB是一个面向文档的数据库系统,与我们平常使用的关系型数据库mysql不同.他使用C++编写,不支持SQL,但有自己功能强大的查询语法.MongoDB使用BSON作为数据存储和传输的格式.BSON 是一种类似JSON的二进制序列化文档,支持嵌套对象和数组.MongoDB很像MySQL,document对应MySQL的 row,collection对应MySQL的table.是当前NoSql数据库中比较热门的一种.它在许多场景下可用于替代传统的关系型数据库或键/

Freebsd 6.2安装配置笔记

#最小化安装后-. sysinstall,改口令,时区,src-sys,ports,man,Xorg, bash3,cvsup-without-gui,lynx,linux,unzip 并设置网卡,sshd服务 ++开启sshd服务 vi /etc/ssh/sshd_config ,加入以下行 PermitRootLogin yes 退出后重启服务即可 /etc/rc.d/sshd restart ++csh改bash chfn -s /usr/local/bin/bash username +