使用Python实现操作mongodb详解

 更新时间:2025年01月28日 10:29:42   作者:qq_44801116  
这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

一、示例

from pymongo import MongoClient
from urllib.parse import quote
class test_mongo:
    def __init__(self, host,port,user,pwd,db):
        self.host = host
        self.port = port
        self.user = user
        self.pwd = pwd
        self.db = db

    def build_conn_mongo(self):
        """
        功能:实现创建客户端
        :return: client
        """
        escaped_username = quote(self.user, safe='')
        escaped_password = quote(self.pwd, safe='')
        # 创建客户端对象,连接MongoDB服务器
        client = MongoClient('mongodb://{0}:{1}@{2}:{3}/{4}'.format(escaped_username, escaped_password, self.host, self.port, self.db))
        return client

    def check_mongo(self,query=None):
        """
        功能:查询信息
        :param query:输入查询条件  eg:{"paId": "38ffefbe29ddcf3c9f574aa"}
        :return:返回信息,以及获取查询的条数
        """
        client = self.build_conn_mongo()
        db = client.iot_ota
        collection = db.集合名称
        results = collection.find(query)
        count= collection.count_documents(query)
        client.close()
        return results,count

    def update_mongo_by_query(self,query, set_value):
        """
        功能:按照条件修改一个记录
        :param query:输入查询条件  eg:query1 = {"paId": "38ffefbe291a375c4aa"}
        :param set_value:eg:{"$set":{"description":"yz测试"}}
        :return:返回基本信息
        """
        client = self.build_conn_mongo()
        db = client.iot_ota
        collection = db.集合名称
        results = collection.update_one(query, set_value)
        client.close()
        return results

    def delete_package_by_query(self,query):
        """
        功能:按照条件删除一个记录
        :param query:输入查询条件  eg:{"otId":202501221}
        :return:
        """
        client = self.build_conn_mongo()
        db = client.iot_ota
        collection = db.集合名称
        results = collection.delete_one(query)
        client.close()
        return results

二、常用指令

序号指令描述
1db = client.数据库名获取数据库
2db.collection.find()筛选所有记录
3db.collection.find({“key”:value})按照条件进行查询记录
4db.collection.count_documents(query)按照条件查询符合记录的条数
5db.collection.update_one(query, set_value))更新一条记录
6db.collection.delete_one(query)删除一条记录

三、遇到的问题

1、转义账户和密码,解决不符合RFC规范的问题

由于使用账号和密码中包含特殊字符出发点报如下错误:

Username and password must be escaped according to RFC 3986, use urllib.parse.quote_plus

解决办法:

用Python的urllib.parse模块中的quote函数来对用户名和密码进行转义

2、未指定权限内数据库,导致报权限错误

报错:pymongo.errors.OperationFailure: Authentication failed具体如下图

解决办法:–由于使用的账户的权限只有更db_name的权限,此处如不指明具体的数据库,则无法访问client = MongoClient(‘mongodb://{0}:{1}@X.x.x.x:27017/db_name’.format(escaped_username,escaped_password))

3、较新版本的PyMongo中,update和remove方法已经被弃用

解决方法:

使用update_one()和update_many()方法来进行单条记录或多条记录的更新操作

使用delete_one和delete_many方法来替代‌remove

到此这篇关于使用Python实现操作mongodb详解的文章就介绍到这了,更多相关Python操作mongodb内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python实现简单的ui界面的设计步骤(适合小白)

    Python实现简单的ui界面的设计步骤(适合小白)

    当我们书写一个python程序时,我们在控制台输入信息时,往往多有不便,并且为了更加美观且直观的方式输入控制命令,我们常常设计一个ui界面,这样就能方便执行相关功能,如计算器、日历等界面,本博客是为了给ui设计的小白进行讲解,需要的朋友可以参考下
    2024-07-07
  • 详解Python中Pygame键盘事件

    详解Python中Pygame键盘事件

    今天给大家带来的是关于Python的相关知识,文章围绕着Pygame键盘事件展开,文中有非常详细的介绍及代码示例,需要的朋友可以参考下
    2021-06-06
  • 十个常见的Python脚本详细介绍及代码举例

    十个常见的Python脚本详细介绍及代码举例

    这篇文章主要给大家介绍了十个常见的Python脚本的相关资料,包括批量重命名文件、下载网页图片、发送邮件通知、读取和写入CSV文件、爬取网页数据、自动化测试、图像处理、数据可视化以及创建简单的Web应用,需要的朋友可以参考下
    2024-11-11
  • Python3中.whl文件创建及使用

    Python3中.whl文件创建及使用

    本文主要介绍了Python3中.whl文件创建及使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • 使用Python的PEAK来适配协议的教程

    使用Python的PEAK来适配协议的教程

    这篇文章主要介绍了使用Python的PEAK来适配协议的教程,来自于IBM官方网站技术文档,需要的朋友可以参考下
    2015-04-04
  • python 已知平行四边形三个点,求第四个点的案例

    python 已知平行四边形三个点,求第四个点的案例

    这篇文章主要介绍了python 已知平行四边形三个点,求第四个点的案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-04-04
  • Django中常遇到的错误问题

    Django中常遇到的错误问题

    在Django开发中,设置DEBUG=False时需要配置ALLOWED_HOSTS以防止报错,此外,如果django-admin.py命令找不到,需添加Django的安装路径到系统环境变量,此文还提供了一些常见Django错误的解决方法,如数据库添加中文报错、信号无法触发等问题
    2024-09-09
  • Django组件content-type使用方法详解

    Django组件content-type使用方法详解

    这篇文章主要介绍了Django组件content-type使用方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-07-07
  • python批量爬取图片的方法详解

    python批量爬取图片的方法详解

    这篇文章给大家介绍了如何使用python批量爬取图片,文中通过代码示例给大家介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2023-12-12
  • Python实现读取HTML表格 pd.read_html()

    Python实现读取HTML表格 pd.read_html()

    这篇文章主要介绍了Python实现读取HTML表格 pd.read_html(),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07

最新评论