python 操作 mongodb 最常用的方式是通过 pymongo 库实现,具体步骤如下:1. 安装 pymongo,使用 pip install pymongo 命令并可通过 python -c "import pymongo; print(pymongo.__version__)" 验证安装;2. 连接数据库,通过 mongoclient 创建客户端对象,支持默认连接、指定 host 和 port 或使用 uri 的方式;3. 插入数据,使用 insert_one() 或 insert_many() 方法插入单条或多条数据,数据格式为字典或字典列表;4. 查询数据,使用 find_one() 查询单条数据,find() 查询多条数据,并可结合条件及 sort() 实现排序。
Python 操作 mongodb 最常用的方式是通过 pymongo 库来实现。它提供了简单、高效的接口,能够轻松完成数据库连接、数据增删改查等常见操作。
安装 pymongo
在开始之前,你需要先安装 pymongo 包。可以通过 pip 命令快速安装:
pip install pymongo
这一步很简单,但很多人容易忽略是否已经安装成功。可以用下面的命令检查是否报错:
立即学习“Python免费学习笔记(深入)”;
python -c "import pymongo; print(pymongo.__version__)"
如果输出了版本号,说明安装没问题。
连接 MongoDB 数据库
使用 pymongo 连接 MongoDB 的第一步是创建一个客户端对象。你可以通过指定 URI 或者主机地址和端口来连接。
from pymongo import MongoClient # 方式一:默认本地连接 client = MongoClient() # 方式二:指定 host 和 port client = MongoClient('localhost', 27017) # 方式三:远程服务器或 Atlas 使用 URI client = MongoClient('mongodb://username:password@host:port/')
- 默认情况下,MongoDB 的本地服务运行在 localhost:27017。
- 如果你使用的是云服务(如 MongoDB Atlas),则需要使用完整的 URI 地址,并包含用户名和密码。
连接之后,你可以访问具体的数据库和集合:
db = client['mydatabase'] collection = db['mycollection']
注意:这些名字不需要提前存在,第一次插入数据时会自动创建。
插入数据的基本方法
向集合中插入数据是最基础的操作之一。最常用的方法是使用 insert_one() 或 insert_many()。
# 插入单条数据 post = { "title": "Hello MongoDB", "author": "Tom", "tags": ["mongodb", "pymongo"] } collection.insert_one(post) # 插入多条数据 posts = [ {"title": "Post 1", "author": "Jerry"}, {"title": "Post 2", "author": "Alice"} ] collection.insert_many(posts)
几点注意事项:
- 插入的数据格式必须是字典或字典列表。
- 插入后,MongoDB 会自动生成 _id 字段作为主键。
- 如果你不想用自动生成的 _id,可以在插入前手动指定。
查询数据的几种方式
查询是数据库操作中最常见的需求。pymongo 提供了多种查询方法。
查询一条数据
result = collection.find_one({"author": "Tom"}) print(result)
查询多条数据
results = collection.find({"author": "Jerry"}) for item in results: print(item)
条件查询与排序
# 查询并按 title 排序 results = collection.find({"author": "Jerry"}).sort("title", 1)
- 第二个参数 1 表示升序,-1 表示降序。
- 可以组合多个条件,比如 {“author”: “Jerry”, “title”: “Post 1”}。
查询时可以灵活使用 $gt、$lt 等操作符做范围判断,也可以使用正则表达式进行模糊匹配。
基本上就这些。
连接、插入、查询是最常用的几个功能,掌握了这几个步骤,就可以在 Python 中顺利操作 MongoDB 了。其他更新、删除等操作也类似,建议查阅官方文档进一步了解。