2024年Python最全MongoDB的聚合操作以及与Python的交互_mongodb aggregate python,字节跳动面试经验

一、Python所有方向的学习路线

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

二、学习软件

工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

三、入门学习视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

{ “_id” : 1, “name” : “小然”, “gender” : 1, “age” : 22, “score” : 95 }
{ “_id” : 2, “name” : “小红”, “gender” : 0, “age” : 18, “score” : 80 }
{ “_id” : 3, “name” : “小亮”, “gender” : 1, “age” : 19, “score” : 60 }
{ “_id” : 4, “name” : “小强”, “gender” : 1, “age” : 23, “score” : 70 }
{ “_id” : 5, “name” : “小柔”, “gender” : 0, “age” : 20, “score” : 85 }
{ “_id” : 6, “name” : “小雷”, “gender” : 1, “age” : 25, “score” : 65 }
{ “_id” : 7, “name” : “小冉”, “gender” : 0, “age” : 19, “score” : 70 }
{ “_id” : 8, “name” : “小晴”, “gender” : 0, “age” : 18, “score” : 90 }
{ “_id” : 9, “name” : “小齐”, “gender” : 1, “age” : 24, “score” : 50 }


* **以性别进行分组**



db.students.aggregate({KaTeX parse error: Expected '}', got 'EOF' at end of input: group:{_id:"gender"}})


输出结果为:


![](https://img2.tuicool.com/zY7rEzE.png!web)


* **统计整个文档,获得数据个数和平均分数**



db.students.aggregate({KaTeX parse error: Expected '}', got 'EOF' at end of input: … count:{sum:1},
avg_score:{ a v g : " avg:" avg:"score"}
}})


输出结果为:


![](https://img1.tuicool.com/ZFZ7veN.png!web)


* **以性别进行分组,获取不同分组中数据的个数和平均分数**



db.students.aggregate({KaTeX parse error: Expected '}', got 'EOF' at end of input: …{ _id:"gender",
count:{KaTeX parse error: Expected 'EOF', got '}' at position 6: sum:1}̲, avg_s…avg:“$score”}
}})


输出结果为:


![](https://img0.tuicool.com/fMvEfyq.png!web)


* **使用 `$project` 修改输出结果**



db.students.aggregate(
{KaTeX parse error: Expected '}', got 'EOF' at end of input: … _id:"gender",
count:{KaTeX parse error: Expected 'EOF', got '}' at position 6: sum:1}̲, a…avg:“KaTeX parse error: Expected 'EOF', got '}' at position 7: score"}̲} }, …project:{
gender:” i d " , c o u n t : 1 , i d : 0 , a v g s c o r e : " _id", count:1, _id:0, avg_score:" id",count:1,id:0,avgscore:"avg_score"}
}
)


输出结果为:


![](https://img2.tuicool.com/V73uI3f.png!web)


* 使用 `$match` 选择分数大于等于70的学生,统计男生、女生的人数



db.students.aggregate(
{KaTeX parse error: Expected '}', got 'EOF' at end of input: match:{score:{gte:70}}},
{KaTeX parse error: Expected '}', got 'EOF' at end of input: group:{_id:"gender",count:{KaTeX parse error: Expected 'EOF', got '}' at position 6: sum:1}̲}}, {project:{gender:“$_id”,count:1,_id:0}}
)


输出结果为:


![](https://img2.tuicool.com/3uINvaB.png!web)


### MondoDB与Python的交互


pymongo的安装


使用Python操作MongoDB需要安装 `pymongo` ,安装方法很简单,使用 `pip install pymongo`即可。


实例化并建立连接


首先从 `pymongo` 中导入 `MongoClient` ,然后实例化 `client` ,建立连接,代码如下:



from pymongo import MongoClient

client = MongoClient(host = "127.0.0.1",port = 27017)
    #操作本机MongoDB可以写成client = MongoClient()
collection = client["test"]["test"]

常用操作实例


* **插入一条数据**



collection.insert_one({“_id”:0,“name”:“test0”})


* **插入多条数据**



data_list = [{“_id”:i,“name”:“test{}”.format(i)} for i in range(10)]
collection.insert_many(data_list)
data_list = [{“name”:“test{}”.format(i)} for i in range(10)]
collection.insert_many(data_list)


插入后结果如下图所示, **下面的操作都在此数据库上进行操作。**


![](https://img2.tuicool.com/YFvM327.png!web)


* **查询一条记录**



print(collection.find_one({“name”:“test2”}))


输出结果为:


![](https://img1.tuicool.com/MzUBraE.png!web)


* **查询所有记录**



result = collection.find({“name”:“test2”})
for i in result:
print(i)


输出结果为:


![](https://img1.tuicool.com/qqUjmaZ.png!web)


* **更新一条数据**



(1)Python所有方向的学习路线(新版)

这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

最近我才对这些路线做了一下新的更新,知识体系更全面了。

在这里插入图片描述

(2)Python学习视频

包含了Python入门、爬虫、数据分析和web开发的学习视频,总共100多个,虽然没有那么全面,但是对于入门来说是没问题的,学完这些之后,你可以按照我上面的学习路线去网上找其他的知识资源进行进阶。

在这里插入图片描述

(3)100多个练手项目

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了,只是里面的项目比较多,水平也是参差不齐,大家可以挑自己能做的项目去练练。

在这里插入图片描述

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 25
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值