pymongo连接MongoDB

导语

pymongo 是目前用的相对普遍一个python用来连接MongoDB的库,是工作中各种基本需求都能满足
具体api可以参考

pymongo API
pymongo github

安装 MongoDB

为了测试pyMongo连接mongodb,首先当然需要在centos下安装mongo,详细参考Centos下安装MongoDB

安装 pymongo

如果没有pip, 建议先安装,至于为啥要用pip你懂得

yum install python-pip

pip 安装 pymongo

pip install pymongo

查看 pymongo是否安装成功

[email protected]/4 $ python
Python 2.7.5 (default, Nov 20 2015, 02:00:19)
[GCC 4.8.5 20150623 (Red Hat 4.8.5-4)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import pymongo
>>> pymongo.version
‘3.2.2‘

使用 pymongo

连接到 MongoDB

有两种方式,等同

>>> client = pymongo.MongoClient(‘192.168.100.3‘, 27017)
>>> print client
MongoClient(host=[‘192.168.100.3:27017‘], document_class=dict, tz_aware=False, connect=True)
>>> client2 = pymongo.MongoClient(‘mongodb://192.168.100.3:27017/‘)
>>> print client2
MongoClient(host=[‘192.168.100.3:27017‘], document_class=dict, tz_aware=False, connect=True)
>>>

得到 db 和 collection

有时候在脚本中会把 db 和 collection 作为参数使用,可以参考第二种方式

直接链接

>>> db = client.report
>>> print db
Database(MongoClient(host=[‘192.168.100.3:27017‘], document_class=dict, tz_aware=False, connect=True), u‘report‘)
>>> collection = db.source_register
>>> print collection
Collection(Database(MongoClient(host=[‘192.168.100.3:27017‘], document_class=dict, tz_aware=False, connect=True), u‘report‘), u‘source_register‘)
>>>

参数链接, 这种形式又有两种方法

## 定义参数
>>> pramadb = ‘report‘
>>> pramacoll = ‘source_register‘

## get db
>>> db2 = client[pramadb]
>>> db3 = client.get_database(pramadb)
>>> print db2
Database(MongoClient(host=[‘192.168.100.3:27017‘], document_class=dict, tz_aware=False, connect=True), u‘report‘)
>>> print db3
Database(MongoClient(host=[‘192.168.100.3:27017‘], document_class=dict, tz_aware=False, connect=True), u‘report‘)
>>> 

## get collection
>>> coll2 = db2[pramacoll]
>>> coll3 = db3.get_collection(pramacoll)
>>> print coll2
Collection(Database(MongoClient(host=[‘192.168.100.3:27017‘], document_class=dict, tz_aware=False, connect=True), u‘report‘), u‘source_register‘)
>>> print coll3
Collection(Database(MongoClient(host=[‘192.168.100.3:27017‘], document_class=dict, tz_aware=False, connect=True), u‘report‘), u‘source_register‘)
>>>

常规操作举例

## insert or save
>>> mydict = {"name":"James", "age": 28}
>>> collection.save(mydict)
ObjectId(‘57fdf212bcd34f48c4fce15a‘)

## find
>>> collection.find({"name":"James"})[0]
{u‘age‘: 28, u‘_id‘: ObjectId(‘57fdf212bcd34f48c4fce15a‘), u‘name‘: u‘James‘}
>>>
时间: 2024-11-10 15:02:35

pymongo连接MongoDB的相关文章

初窥Python(一)——使用pymongo连接MongoDB

Python 可以使用 pymongo 库方便的操作 MongoDB .插播一句,MongoDB 不同于关系型结构的三层结构--database--> table --> record,它的层级为 database -->collection --> document .这里不重点介绍 MongoDB  用法,主要来看一下如何用 Python 使用 MongoDB. 1.安装MongoDB和pymongo: [[email protected] ~]# pip install py

使用pymongo连接mongodb时报错:pymongo.errors.OperationFailure: not authorized

连接本机或局域网部署的mongodb时可以用以下方法: 1 from urllib import parse 2 from pymongo import MongoClient 3 4 host = '*.*.*.*' 5 username = '*****' 6 password = '****' 7 passwd = parse.quote(password) # 对密码先进行编码 8 port = '3717' 9 mongo_url = 'mongodb://{0}:{1}@{2}:{3

远程连接mongodb时,27017端口连接不上的解决办法

一.背景描述: 我在linux  RED7上安装了mongodb,并没有修改mongodb的配置文件.然后通过另外一台电脑用pymongo连接mongodb时,报错:timeout. ping IP 是成功的. telnet IP 27017 的时候,提示:27017端口连接不上. 二.解决过程: 各种百度,远程连接mongodb失败,网上资料显示原因有两个: 1.mongodb的配置文件中的bind_ip 默认为127.0.0.1,默认只有本机可以连接.  此时,需要将bind_ip配置为0.

Python 连接MongoDB并比较两个字符串相似度的简单示例

本文介绍一个示例:使用 pymongo 连接 MongoDB,查询MongoDB中的 字符串 记录,并比较字符串之间的相似度. 一,Python连接MongoDB 大致步骤:创建MongoClient---> 获取 DataBase --->获取Collection,代码如下: client = MongoClient(host="127.0.0.1", port=10001) db = client['database_name'] db.authenticate(nam

python连接mongodb并操作

安装python连接mongodb的库文件pymongo pip install pymongo python连接mongodb程序 import pymongo conn = pymongo.MongoClient("ip",端口) db = conn.admin #连接库 db.authenticate("账号","密码") #用户认证 db=conn.jwh db.test.insert({'id':1,'name':'kaka','sex

【mongodb 学习一】环境搭建之 mac 下连接 mongodb 的UI 客户端

记录下 mongodb 的学习 懒得自己达 mongodb 的服务器了 虽然一句命令就能搞定了 brew install mongodb 可是考虑到以后的应用还是放在网上的,就直接用现成的服务吧 下载客户端(robomongo 是多平台,开源免费得的,windows,mac,linux都有) http://robomongo.org/ 下载就不多说了,按自己需要的平台来下载就行了 去 mongodblab.com 注册个免费得500M 数据库 https://mongolab.com/welco

Python 使用pymongo操作mongodb库

1,安装python3.5 如果python还没有安装,可以直接用yum安装, [python] view plain copy # 不过安装的是2.6 version yum install -y python 源码安装3.5 [python] view plain copy wget https://www.python.org/ftp/python/3.5.0/Python-3.5.0.tgz tar -xvf Python-3.5.0.tgz cd Python-3.5.0 ./conf

python 连接mongodb ,并将EXCEL文档导入mongodb

一.下载软件 1.https://pypi.python.org/pypi/pymongo/#downloads  下载 PYMONGO 下载后 用命令提示符  cmd进入目录 并运行命令 python setup.py install 2.下载 xlrd  https://pypi.python.org/pypi/xlrd 利用pymongo包进行数据库的连接,使用xlrd包读取excel数据,由于二者数据结构的不同,要将excel格式数据转换为json格式数据.由于编码问题会出现"TypeE

爬虫入门【8】Python连接MongoDB的用法简介

MongoDB的连接和数据存取 MongoDB是一种跨平台,面向文档的NoSQL数据库,提供高性能,高可用性并且易于扩展. 包含数据库,集合,文档等几个重要概念. 我们在这里不介绍MongoDB的特点和用法了,感兴趣的可以查一下官方文档. 在此重点介绍如何使用python连接MongoDB,并通过PyMongo操作MongoDB数据库. 这里默认MongoDB已经安装好啦,安装教程可以参考: http://www.yiibai.com/mongodb/mongodb_environment.ht