Python使用pymongo模块操作MongoDB的方法示例


Posted in Python onJuly 20, 2018

本文实例讲述了Python使用pymongo模块操作MongoDB的方法。分享给大家供大家参考,具体如下:

通过pymongo实现python对Mongodb的操作。

具体看python代码

#!/usr/bin/python
# coding=utf-8
#python实现对MongoDB的操作
#需要安装python2、pymongo、安装pymongo可能需要pip,logging打印日志
#改脚本主要功能就是每5秒改一次mongodb中存储的ip,5秒后再改回来
import pymongo
import logging
import datetime
import os
import time
import traceback
import sys,gc
# 初始化logging
logging.basicConfig(level=logging.NOTSET,
          format='%(asctime)s %(filename)s[line:%(lineno)d] [%(levelname)s] %(message)s',
          datefmt='%Y-%m-%d %H:%M:%S',
          filename='clear_screenshot_based_on_db.log',
          filemode='a')
# set to print log to console at the same time
console = logging.StreamHandler()
console.setLevel(logging.NOTSET)
formatter = logging.Formatter('%(asctime)s %(name)s [%(levelname)s] %(message)s')
console.setFormatter(formatter)
logging.getLogger('').addHandler(console)
class MongoDB_Util():
#写一个类,用于实例化pymongo对象以及对mongo的增删改查
  def __init__(self, user, password, host, port, database, max_pool_size=2):
    try:
      client = pymongo.MongoClient(host=host, port=port, maxPoolSize=max_pool_size)
#实例化对象,需要mongo的相关参数
      if client == None:
        logging.error(
          "MongoDB_Util.__init__ : Initialize mongodb client object error,host:%s port:%s" % (
            host, port))
        raise Exception("Initialize mongodb client object error")
      try:
        admin_db = client['admin']  #指定连接的库
        admin_db.authenticate(user, password) #身份验证
        self.persist_db = admin_db  #赋值属性,通过该属性执行其他操作
      except Exception as exp:
        logging.error(
          "MongoDB_Util.__init__ : Authtication failed,host:%s port:%s database:%s user:%s password:%s" %
          (host, port, database, user, password))
        raise exp
    except Exception as exp:
      logging.error(
        "MongoDB_Util.__init__ : Exception has occured : %s" % str(sys.exc_info()[1]))
      raise exp
  def update(self):
#update方法,对mongodb执行update操作
    tom = None
    try:
      if self.persist_db == None:
        logging.error('MongoDB_Util.delete : Persist object has not been initialised')
        raise Exception('Persist object has not been initialised')
      collection = self.persist_db['fuzzing_agent.configuration']  #链接fuzzing_agent.configuration表
      abc=collection.find({"default_value" : "10.10.1.179"})   #执行find命令
      for i in abc:
        tom = i["default_value"]
      if tom == "10.10.1.179":
    #判断该值是否为179,如果是则通过update改为134
        collection.update({"default_value" : "10.10.1.179"},
                 {'$set':{'default_value': '10.10.1.134'}})
        collection.update({"default_value" : "10.10.1.179:/run/media/root/disk01/fuzzing"},
                 {'$set':{"default_value" :"10.10.1.134:/run/media/root/disk01/fuzzing"}})
        logging.debug("179 > 134")
        time.sleep(5)
      else:
        collection.update({"default_value" : "10.10.1.134"},
                 {'$set':{'default_value': '10.10.1.179'}})
        collection.update({"default_value" : "10.10.1.134:/run/media/root/disk01/fuzzing"},
                 {'$set':{"default_value" :"10.10.1.179:/run/media/root/disk01/fuzzing"}})
        logging.debug("134 > 179")
        time.sleep(5)
      return
    except Exception as exp:
      logging.error('Mongodb_Util.delete : Exception has occured : ' + str(sys.exc_info()[1]))
      raise exp
def change_ip(mongodb_host) :
  result = False
  try :
    mongo_util = MongoDB_Util('username', 'password', mongodb_host, 27017, 'admin',max_pool_size = 2) #用户名,密码,mongodb的Ip,端口,连接库,连接池
    mongo_util.update()
    result = True
  except :
    logging.error('change_ip: Exception has occured : ' + traceback.format_exc())
  finally:
    return result
if __name__ == '__main__' :
  while True :
    try :
      if change_ip(mongodb_host = '127.0.0.1') :



#mongodb的ip地址
        logging.debug('update is done !!!')
      else :
        logging.error('not update done')
    except :
      logging.error('main : Exception has occured : ' + traceback.format_exc())
    finally:
      logging.debug("one loop %s" %datetime.datetime.now())

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python 过滤字符串的技巧,map与itertools.imap
Sep 06 Python
Python通过poll实现异步IO的方法
Jun 04 Python
Python简单生成随机姓名的方法示例
Dec 27 Python
有关Python的22个编程技巧
Aug 29 Python
pow在python中的含义及用法
Jul 11 Python
python3获取文件中url内容并下载代码实例
Dec 27 Python
python读取图片的几种方式及图像宽和高的存储顺序
Feb 11 Python
python递归函数用法详解
Oct 26 Python
如何用python开发Zeroc Ice应用
Jan 29 Python
Python编写可视化界面的全过程(Python+PyCharm+PyQt)
May 17 Python
python中的class_static的@classmethod的巧妙用法
Jun 22 Python
Python 语言实现六大查找算法
Jun 30 Python
Python闭包函数定义与用法分析
Jul 20 #Python
Django rest framework工具包简单用法示例
Jul 20 #Python
Django 中使用流响应处理视频的方法
Jul 20 #Python
Python实现手写一个类似django的web框架示例
Jul 20 #Python
python 实现求解字符串集的最长公共前缀方法
Jul 20 #Python
python实现求两个字符串的最长公共子串方法
Jul 20 #Python
Django基础知识与基本应用入门教程
Jul 20 #Python
You might like
php XMLWriter类的简单示例代码(RSS输出)
2011/09/30 PHP
PHP中mysql_field_type()函数用法
2014/11/24 PHP
codeigniter中view通过循环显示数组数据的方法
2015/03/20 PHP
浅谈mysql_query()函数的返回值问题
2016/09/05 PHP
laravel接管Dingo-api和默认的错误处理方式
2019/10/25 PHP
document对象execCommand的command参数介绍
2006/08/01 Javascript
JavaScript 学习笔记(十二) dom
2010/01/21 Javascript
jQuery 前的按键判断代码
2010/03/19 Javascript
23个超流行的jQuery相册插件整理分享
2011/04/25 Javascript
JS 获取浏览器和屏幕宽高等信息的实现思路及代码
2013/07/31 Javascript
jquery实现手机发送验证码的倒计时代码
2014/02/12 Javascript
Javascript中匿名函数的调用与写法实例详解(多种)
2016/01/26 Javascript
VUEJS实战之利用laypage插件实现分页(3)
2016/06/13 Javascript
JS实现颜色梯度与渐变效果完整实例
2016/12/30 Javascript
关于axios返回空对象的问题解决
2017/04/04 Javascript
微信小程序wx.uploadfile 本地文件转base64的实现代码
2018/06/28 Javascript
js console.log打印对象时属性缺失的解决方法
2019/05/23 Javascript
用smtplib和email封装python发送邮件模块类分享
2014/02/17 Python
Python中常见的数据类型小结
2015/08/29 Python
利用python爬取软考试题之ip自动代理
2017/03/28 Python
Python简单实现Base64编码和解码的方法
2017/04/29 Python
PyCharm在win10的64位系统安装实例
2017/11/26 Python
Python的地形三维可视化Matplotlib和gdal使用实例
2017/12/09 Python
Python去除字符串前后空格的几种方法
2019/03/04 Python
python腾讯语音合成实现过程解析
2019/08/01 Python
Python使用get_text()方法从大段html中提取文本的实例
2019/08/27 Python
如何通过python实现人脸识别验证
2020/01/17 Python
利用setuptools打包python程序的方法步骤
2020/01/18 Python
详解CSS3+JS完美实现放大镜模式
2020/12/03 HTML / CSS
英国创新设计文具、卡片和礼品包装网站:Paperchase
2018/07/14 全球购物
实习单位接收函模板
2014/01/10 职场文书
聊城大学毕业生自荐书
2014/02/01 职场文书
后勤部经理岗位职责
2014/02/23 职场文书
中学生操行评语
2014/04/24 职场文书
给校长的建议书100字
2014/05/16 职场文书
2014年国庆标语
2014/06/30 职场文书