一、安装与更新

pip install pymongo  # 常用安装
pip install pymongo==3.5. # 指定版本安装
pip install --upgrade pymongo # 更新安装

二、创建数据库、集合

#!/usr/bin/python3
# -*- coding: utf- -*-
import pymongo dbcon = pymongo.MongoClient("mongodb://10.x.x.x:27017") # 连接数据库
print(dbcon.database_names()) # 已存在的数据库 结果: ['admin', 'config', 'lion', 'local'] mydb = dbcon["lion"] # 选择lion数据库
print(mydb.collection_names()) # 已存在的集合 mycol = mydb["kzg_col"] # 选择集合

  

三、插入数据

  1、插入单条数据(返回一个id)

#!/usr/bin/python3
# -*- coding: utf- -*-
import pymongo dbcon = pymongo.MongoClient("mongodb://10.x.x.x:27017") # 连接数据库
mydb = dbcon["lion"] # 选择lion数据库
mycol = mydb["kzg_col"] # 选择集合名 insertData = { "name": "RUNOOB2", "alexa": "", "url": "https://www.runoob.com" }
ins = mycol.insert_one(insertData) # 插入一条数据
print(ins.inserted_id) 结果: 5d81f4961565d78070165d24

  2、插入多条数据(返回多个id)

#!/usr/bin/python3
# -*- coding: utf- -*-
import pymongo dbcon = pymongo.MongoClient("mongodb://10.20.x.x:27017") # 连接数据库
mydb = dbcon["lion"] # 选择lion数据库
mycol = mydb["kzg_col"] # 选择集合名 mylist = [
{ "name": "Taobao", "alexa": "", "url": "https://www.taobao.com" },
{ "name": "QQ", "alexa": "", "url": "https://www.qq.com" },
{ "name": "Facebook", "alexa": "", "url": "https://www.facebook.com" },
{ "name": "知乎", "alexa": "", "url": "https://www.zhihu.com" },
{ "name": "Github", "alexa": "", "url": "https://www.github.com" }
]
ins = mycol.insert_many(mylist) # 插入多条数据
print(ins.inserted_ids)

  3、插入的数据可以指定id吗

mylist = [
{ "_id": , "name": "RUNOOB", "cn_name": "菜鸟教程"},
{ "_id": , "name": "Google", "address": "Google 搜索"},
{ "_id": , "name": "Facebook", "address": "脸书"},
{ "_id": , "name": "Taobao", "address": "淘宝"},
{ "_id": , "name": "Zhihu", "address": "知乎"}
]
ins = mycol.insert_many(mylist) # 插入多条数据
print(ins.inserted_ids)
结果:[, , , , ]

四、删除数据

  1、删除一条数据

#!/usr/bin/python3
# -*- coding: utf- -*-
import pymongo dbcon = pymongo.MongoClient("mongodb://10.x.x.x:x") # 连接数据库
mydb = dbcon["lion"] # 选择lion数据库
mycol = mydb["kzg_col"] # 选择集合名 qu = {"name":"RUNOOB"}
print(mycol.find().count()) # 总数18
print(mycol.find(qu).count()) # 待删除数据2
print(mycol.delete_one(qu)) # 删除1条
print(mycol.find().count()) # 剩17条
print(mycol.find().count())  # 总数17
print(mycol.find_one_and_delete(qu)) # 返回删除的数据
print(mycol.find().count()) # 剩16条

  2、一次删除多条数据

#!/usr/bin/python3
# -*- coding: utf-8 -*-
import pymongo dbcon = pymongo.MongoClient("mongodb://10.x.x.x:27017") # 连接数据库
mydb = dbcon["lion"] # 选择lion数据库
mycol = mydb["kzg_col"] # 选择集合名 qu = {"name": {"$regex":"^F"}} print(mycol.find().count()) # 总数16
print(mycol.find(qu).count()) # 符合查询条件3条
d = mycol.delete_many(qu) # 删除多条
print(d.deleted_count) # 已删除3条
d = mycol.delete_many({}) # 删除所有数据(集合存在, 数据为空)
mycol.drop() # 删除集合
print(mycol.find().count()) # 总数13条

五、修改数据

  1、修改一条数据

#!/usr/bin/python3
# -*- coding: utf-8 -*-
import pymongo dbcon = pymongo.MongoClient("mongodb://10.20.6.36:27017") # 连接数据库
mydb = dbcon["lion"]  # 选择lion数据库
mycol = mydb["kzg_col"] # 选择集合名 myq = {"name": "Taobao"} # 查询name=Taobao
myq = {"name": {"$regex":"^F"}} # 查询 name以F开头
myu = {"$set": {"alexa": 200}} # 更新 alexa=200 u = mycol.update_one(myq, myu) # 一次更新一条
u = mycol.update_many(myq, myu) # 一次更新多条
print(u.modified_count) # 修改数量

六、查询

#!/usr/bin/python3
# -*- coding: utf- -*-
import pymongo dbcon = pymongo.MongoClient("mongodb://10.20.6.36:27017") # 连接数据库
mydb = dbcon["lion"] # 选择lion数据库
mycol = mydb["kzg_col"] # 选择集合名 mycol.find_one() # 查询集合中的第一条数据
mycol.find() # 查询集合中的所有数据
# 0不返回 1返回 ,_id 列不特指默认返回
for x in mycol.find({}, {"_id": , "name": , "alexa": }):
print(x)
# 除了字段alexa不显示, 其它的都显示
for x in mycol.find({}, {"alexa": }):
print(x)
# 只显示_id和alexa字段
for x in mycol.find({}, {"alexa": }):
print(x)
# 指定查询条件
mydoc = mycol.find({"name": "Taobao"})
for d in mydoc:
print(d)
# 高级查询(name字段第一个字母大于H的数据)
mydoc = mycol.find({"name":{"$gt":"H"}})
# 正则表达式(查询字符串的字段)
mydoc = mycol.find({"name":{"$regex":"^G"}})
# 返回指定数量的条数
res = mycol.find().limit()
print(res.count()) # 总数5条
for x in res: # 实际返回3条
print(x)

七、排序

#!/usr/bin/python3
# -*- coding: utf- -*-
import pymongo dbcon = pymongo.MongoClient("mongodb://10.20.6.36:27017") # 连接数据库
mydb = dbcon["lion"] # 选择lion数据库
mycol = mydb["kzg_col"] # 选择集合名 # sort 第一个参数为排序字段, 第二个参数1为升序, - 为降序, 默认升序
mydoc = mycol.find().sort("alexa", -)
for d in mydoc:
print(d)

pymongo的用法的更多相关文章

  1. Python3中PyMongo的用法

    MongoDB存储 在这里我们来看一下Python3下MongoDB的存储操作,在本节开始之前请确保你已经安装好了MongoDB并启动了其服务,另外安装好了Python的PyMongo库. 连接Mon ...

  2. MongoDB和pymongo自用手册

    [*] 本文出处:http://b1u3buf4.xyz/ [*] 本文作者:B1u3Buf4 [*] 本文授权:禁止转载 从自己的另一处博客移动过来.长期维护,不定期添加新内容. 前述和安装 mon ...

  3. 当用户管理系统遇上python和mongodb后……

    Overview: 环境 前言 效果图 mongdb安装 代码涉及知识点 关于windows的cmd下执行python文件显示中文乱码的问题 总结 0.环境 操作系统:Windows Python版本 ...

  4. Python爱好者社区历史文章列表(每周append更新一次)

    2月22日更新:   0.Python从零开始系列连载: Python从零开始系列连载(1)——安装环境 Python从零开始系列连载(2)——jupyter的常用操作 Python从零开始系列连载( ...

  5. mongoDB安装windows 64 bit

    mongoDB安装windows 64 bit   https://www.mongodb.org/downloads?_ga=1.207888916.746558625.1410501054 下载, ...

  6. MongoDB --- 02. 基本操作,增删改查,数据类型,比较符,高级用法,pymongo

    一.基本操作 . mongod 启动服务端 2. mongo 启动客户端 3. show databses 查看本地磁盘的数据库 4. use 库名 切换到要使用的数据库 5. db 查看当前使用的数 ...

  7. pymongo常见的高级用法

    pymongo是python中基于mongodb数据库开发出来的,比mongoengine要高级一些,也要好用一些. 基本的增删查改就不说了 insert() delete() find() upda ...

  8. MondoDB介绍 Python与MongoDB用法,安装PyMongo

    http://blog.csdn.net/t_ells/article/details/50265889 MongoDB最新版本下载在官网的DownLoad菜单下:http://www.mongodb ...

  9. Python爬虫从入门到放弃(十六)之 Scrapy框架中Item Pipeline用法

    当Item 在Spider中被收集之后,就会被传递到Item Pipeline中进行处理 每个item pipeline组件是实现了简单的方法的python类,负责接收到item并通过它执行一些行为, ...

随机推荐

  1. java main()线程是不是最后一个退出的(相比较main中创建的其他多个线程)

    JVM会在所有的非守护线程(用户线程)执行完毕后退出: main线程是用户线程: 仅有main线程一个用户线程执行完毕,不能决定JVM是否退出,也即是说main线程并不一定是最后一个退出的线程. pu ...

  2. vue-cli3 DllPlugin 提取公用库

    vue 开发过程中,保存一次就会编译一次,如果能够减少编译的时间,哪怕是一丁点,也能节省不少时间.开发过程中个人编写的源文件才会频繁变动,而一些库文件我们一般是不会去改动的.如果能把这些库文件提取出来 ...

  3. Python必会的单元测试框架 —— unittest

    用Python搭建自动化测试框架,我们需要组织用例以及测试执行,这里博主推荐Python的标准库——unittest. unittest是xUnit系列框架中的一员,如果你了解xUnit的其他成员,那 ...

  4. DPI 计算及速查表

    [来源]ExMobi 二次开发手册 手机屏幕根据密度范围分为五种:低.中.高.超高.超超高,为了确保界面元素在不同的屏幕都能合适的展示,在设计界面元素的 UI 时,UI 工程师建议统一采用 dpi ( ...

  5. Atom编辑器中安装Emmet插件失败的问题

    今天使用Atom编辑器安装Emmet插件的时候,刚开始的时候报错: 报错内容如下: Installing “emmet@2.4.3” failed.Show output… Compiler tool ...

  6. 面试:C++实现访问者模式

    参考:深入应用C++11,访问者模式 #include <iostream> class ConcreteElement1; class ConcreteElement2; class V ...

  7. 自己动手实现java数据结构(八) 优先级队列

    1.优先级队列介绍 1.1 优先级队列 有时在调度任务时,我们会想要先处理优先级更高的任务.例如,对于同一个柜台,在决定队列中下一个服务的用户时,总是倾向于优先服务VIP用户,而让普通用户等待,即使普 ...

  8. Django 学习笔记(四) --- 模型和数据库

    人生苦短 ~ Tips:仅适用于 Python 3+(反正差别不大,py2 改改也能用).因为据 Python 之父 Guido van Rossum 说会在 2020 年停止对 Python 2 的 ...

  9. #16 os&sys模块

    前言 在编写Python程序的时候,可能需要和操作系统进行交互,比如获取某个目录下的内容.更改运行目录.更改环境变量等操作.在Python中有两个模块将这些问题完美解决,一起看看哇! 一.os模块 o ...

  10. 页面滚动显示或隐藏元素Headroom.js插件帮助你实现滚动效果

    Headroom.js 是什么? Headroom.js 是一个轻量级.高性能的JS小工具(不依赖任何工具库!),它能在页面滚动时做出响应.此页面顶部的导航条就是一个鲜活的案例,当页面向下滚动时,导航 ...