python与mongodb交互-->pymongo

python 复制代码
from pymongo import MongoClient

# 创建数据库连接对象
client=MongoClient('ip',27017)

# 选择一个数据库
db=client['admin']

db.authenticate('python','python')

# 选择一个集合
col=client['pydata']['test']

col.insert({"class":"python"})

col.find()
for data in col.find():
    print(data)


# 更新
col.update({"class":"python40"},{"message":"hello word"})
# 全文档覆盖更新
col.update({},{"$set":{"id":"xxxx-xxxx"}})
col.update({},{"$set":{"id":"xxxx-xxxx"}},multi=True)
col.update({},{"$set":{"id":"xxxx-xxxx"}},upsert=True)

# 删除
col.delete_one({"":""})
col.delete_many({"":""})
  1. $match:根据指定的条件筛选出满足条件的文档,类似于查询操作中的查询条件。

  2. $group:根据指定的字段对文档进行分组,并可以对每个分组进行计算或汇总。可用于计算汇总值、计数、求和、平均值等。

  3. $project:对输入文档进行投影操作,选择需要的字段,并可以对字段进行重命名、计算、转换等操作。类似于查询操作中的投影(Projection)。

  4. $sort:根据指定的字段对文档进行排序,可以按升序或降序排序。

  5. $limit:限制结果集的文档数量,只返回指定数量的文档。

  6. $skip:跳过指定数量的文档,并返回剩余的文档。

  7. $unwind:将包含数组的字段拆分为多个文档,每个文档只包含数组中的一个元素。

  8. $lookup:在不同的集合之间执行左连接操作,可以从其他集合中获取匹配的文档。

这些是一些常见的聚合操作,您可以根据需求组合和使用不同的聚合操作符来构建复杂的聚合管道。聚合操作可以用于实现复杂的数据处理和分析任务,例如数据分组统计、数据透视、数据变换等。

以下是一个示例聚合管道的示例,以展示如何使用多个阶段来完成数据处理:

python 复制代码
db.collection.aggregate([
  { $match: { field: value } },
  { $group: { _id: "$category", total: { $sum: "$quantity" } } },
  { $sort: { total: -1 } },
  { $limit: 5 }
]);
相关推荐
woshikejiaih9 分钟前
**播客听书与有声书区别解析2026指南,适配不同场景的音频
大数据·人工智能·python·音视频
深蓝海拓16 分钟前
PySide6,QCoreApplication::aboutToQuit与QtQore.qAddPostRoutine:退出前后的清理工作
笔记·python·qt·学习·pyqt
Sagittarius_A*19 分钟前
特征检测:SIFT 与 SURF(尺度不变 / 加速稳健特征)【计算机视觉】
图像处理·人工智能·python·opencv·计算机视觉·surf·sift
像风一样的男人@33 分钟前
python --读取psd文件
开发语言·python·深度学习
薛定谔的猫喵喵41 分钟前
天然气压力能利用系统综合性评价平台:基于Python和PyQt5的AHP与模糊综合评价集成应用
开发语言·python·qt
yuluo_YX1 小时前
Reactive 编程 - Java Reactor
java·python·apache
独好紫罗兰1 小时前
对python的再认识-基于数据结构进行-a004-列表-实用事务
开发语言·数据结构·python
ZH15455891311 小时前
Flutter for OpenHarmony Python学习助手实战:模块与包管理的实现
python·学习·flutter
choke2331 小时前
[特殊字符] Python异常处理
开发语言·python
玄同7652 小时前
从 0 到 1:用 Python 开发 MCP 工具,让 AI 智能体拥有 “超能力”
开发语言·人工智能·python·agent·ai编程·mcp·trae