# coding:utf-8
"""
mongo操作工具
""" from pymongo import MongoClient
MONGO_HOST, MONGO_PORT, MONGO_DB, MONGO_TABLE = '127.0.0.1', '', 'test_db', 'teat_tb' class MongoUtils:
"""
链接mongoDB,进行各种操作
"""
def __init__(self, host=MONGO_HOST, port=MONGO_PORT, db_name=MONGO_DB):
"""
初始化对象,链接数据库
:param host: mongo数据库所在服务器地址
:param port: mongo数据库端口
:param db_name: 数据库的名称
:return: 无返回值
"""
try:
self.client = None
self.client = MongoClient(host, port)
self.database = self.client.get_database(db_name)
self.collection = None
except Exception as e:
self.close_conn()
print('init mongo bar failed: %s' % e) def change_collection(self, table_name=MONGO_TABLE):
"""切换表"""
self.collection = self.database.get_collection(table_name) def count_info(self, table_name=MONGO_TABLE, filter_dict=None):
"""
查找表记录条数,默认返回0
:param table_name: str 表名
:param filter_dict: dict 过滤条件
:return: int 表记录条数
"""
tab_size = 0
try:
self.collection = self.database.get_collection(table_name)
tab_size = self.collection.find(filter_dict).count()
return tab_size
except Exception as e:
print('get table size failed: %s' % e)
finally:
return tab_size def update_info(self, filter_dict, update_dict, insert=False, multi=False):
"""
更新表记录,默认返回false
:param filter_dict: dict 过滤条件,如{'campaignId':{'$in':[1,2,3]}}
:param update_dict: dict 更新的字段,如{'$set':{status_key:0,'campaign.status':1},{'$unset':'campaign.name':'test_camp'}}
:param insert: bool 如果需要更新的记录不存在是否插入
:param multi: bool 是否更新所有符合条件的记录, False则只更新一条,True则更新所有
:return: bool 是否更新成功
"""
result = False
try:
self.collection.update(filter_dict, update_dict, insert, multi)
result = True
print("[INFO] update success!")
except Exception as e:
print('update failed: %s' % e)
finally:
return result def insert_info(self, insert_date):
"""
更新表记录,默认返回false
:param insert_date: dict 插入的数据,如{'campaignId':{'$in':[1,2,3]}}
:return: bool 是否更新成功
"""
result = False
try:
self.collection.insert(insert_date)
result = True
print("insert success!")
except Exception as e:
print('insert failed: %s' % e)
finally:
return result def delete_info(self, filter_date):
"""
更新表记录,默认返回false
:param filter_date: dict 删除数据的条件,如{'campaignId':{'$in':[1,2,3]}}
:return: bool 是否更新成功
"""
result = False
try:
self.collection.remove(filter_date)
result = True
print("remove success!")
except Exception as e:
print('remove failed: %s' % e)
finally:
return result def find_one_info(self, filter_dict, return_dict):
"""
查找一条表记录,默认返回空字典
:param filter_dict: dict 过滤条件如{'campaignId':123}
:param return_dict: dict 返回的字段如{'campaign.status':1,'updated':1,'_id':0}
:return: dict 查找到的数据
"""
result = {}
try:
result = self.collection.find_one(filter_dict, return_dict)
except Exception as e:
print('find data failed: %s' % e)
finally:
return result def find_multi_info(self, filter_dict, return_dict, limit_size=0, skip_index=0):
"""
查找多条表记录,默认返回空数组
:param filter_dict: dict filter_dict: 过滤条件如{'campaignId':123}
:param return_dict: dict 返回的字段如{'campaign.status':1,'updated':1,'_id':0}
:param limit_size: int 限定返回的数据条数
:param skip_index: int 游标位移
:return: list 查询到的记录组成的列表,每个元素是一个字典
"""
result = []
try:
if not limit_size:
if not skip_index:
result = self.collection.find(filter_dict, return_dict)
else:
result = self.collection.find(filter_dict, return_dict).skip(skip_index)
else:
if not skip_index:
result = self.collection.find(filter_dict, return_dict).limit(limit_size)
else:
result = self.collection.find(filter_dict, return_dict).skip(skip_index).limit(limit_size)
except Exception as e:
print('find data failed: %s' % e)
finally:
return result def close_conn(self):
"""
关闭数据库链接
:return: 无返回值
"""
if self.client:
self.client.close()

python操作mongo实例的更多相关文章

  1. Python操作Mysql实例代码教程在线版(查询手册)_python

    实例1.取得MYSQL的版本 在windows环境下安装mysql模块用于python开发 MySQL-python Windows下EXE安装文件下载 复制代码 代码如下: # -*- coding ...

  2. Python操作Mysql实例代码教程在线版(查询手册)

    本文介绍了Python操作MYSQL.执行SQL语句.获取结果集.遍历结果集.取得某个字段.获取表字段名.将图片插入数据库.执行事务等各种代码实例和详细介绍,代码居多,是一桌丰盛唯美的代码大餐   实 ...

  3. 利用python操作mrjob实例---wordcount

       网上利用java实现mr操作实例相对较多,现将python实现mr操作实例---Wordcount分享如下: 在操作前,需要作如下准备: 1.确保linux系统里安装有python3.5,pyt ...

  4. python操作mongo脚本

    #!/usr/bin/python# -*- coding: utf-8 -*- import sysimport osimport jsonfrom pymongo import MongoClie ...

  5. Python操作Mongo数据库

    连接数据库 import pymongo # 连接到数据库,以下两种方式均可 client = pymongo.MongoClient(host='localhost', port=27017) cl ...

  6. python操作mysql实例

    #coding=utf-8 import MySQLdb # 打开数据库连接 db = MySQLdb.connect(host='localhost',user='root',passwd='',d ...

  7. python 操作mongo

    1. 导包: import pymongo 2. 建立连接 client = pymongo.MongoClient("127.0.0.1",27017) 3. 获取数据库 db ...

  8. python操作mongodb实例

    安装pymongo扩展 import pymongo; client = pymongo.MongoClient(host='10.48.176.170',port=27017); db = clie ...

  9. Python学习笔记(五)之Python操作Redis、mysql、mongodb数据库

    操作数据库 一.数据库 数据库类型主要有关系型数据库和菲关系型数据库. 数据库:用来存储和管理数的仓库,数据库是通过依据“数据结构”将数据格式化,以记录->表->库的关系存储.因此数据查询 ...

随机推荐

  1. js限制按钮每隔一段时间才能再次点击

    设置属性 disabled 可以限制交互,单击按钮时添加disabled=“disabled”属性,再为按钮添加定时器,一定时间后删除定时器和disabled属性 <!DOCTYPE html& ...

  2. 工控安全-PLC指纹提取的几种方法

    前言:PLC为可编程逻辑控制器,采用S7协议.其硬件本身存在许多漏洞,可以利用kali里面的漏洞模块或者modbus工具对其进行攻击,甚至直接可以进行未授权访问,只要其开启对外网的端口服务,那么我们就 ...

  3. hdu 1087 Super Jumping!(类最长上升子序列)

    题意:在一组数中选取一个上升子序列,使得这个子序列的和最大. 解:和最长上升子序列dp过程相似,设dp[i]为以第i位为结尾最大和,那么dp[i]等于max(dp[0],dp[1],,,,,dp[i- ...

  4. 小白月赛22 B : 树上子链

    B:树上子链 考察点 : 树的直径 坑点 : long long, 是点权不是边权 一个点也算一条链 析题得侃: 关于树的直径 这道题考察的是树的直径,最好用树形DP来写,具体解释详见上述博客, 这道 ...

  5. 最短路-A - 畅通工程续

    A - 畅通工程续 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过路多了也不好,每次要从一个城镇到另一个城镇时,都有许多种道路方案可以选择,而某些方案要比另一些方案行走的距离要短很多.这 ...

  6. 五、JVM之堆内存

    堆结构分代图 堆结构分代的意义 Java虚拟机根据对象存活的周期不同,把堆内存划分为几块,一般分为新生代.老年代和永久代(对HotSpot虚拟机而言),这就是JVM的内存分代策略. 堆内存是虚拟机管理 ...

  7. MATLAB用“fitgmdist”函数拟合高斯混合模型(一维数据)

    MATLAB用“fitgmdist”函数拟合高斯混合模型(一维数据) 作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 在MATLAB中“fitgmdis ...

  8. ECMAScript基本对象——function定义函数

    function:函数对象=java方法,java的方法或者函数是,java对象的一部分. JavaScript的函数或者方法,就是一个对象实参:都必须具有确定的值, 以便把这些值传送给形参. 形参: ...

  9. CSS隐藏元素的五种方法

    1.opacity:0 2.visibility:hidden 3.diaplay:none 4.position:absolute display display属性依照词义真正隐藏元素.将disp ...

  10. 2018ICPC南京站Problem A. Adrien and Austin

    题意: n个石头再1-n的位置上,两个人轮流取时候,必须取连续的一段,最多取k个,不能取为输,问谁会赢 解析: 当k大于等于2时,先手总能把石头分成相等的两部分,此时后手无论怎么走,先手在对称的位置选 ...