python连接集群mongodb,封装增删改查
1.下载pymongo
pip install pymongo
2.直接上代码
[ini配置文件]

封装读ini省略~~
[db.py]
class Database():
def __init__(self):
self.cf = ConfigParser.ConfigParser()
self.mq = StringManipulation
# 操作mongodb
def db_mongo(self,Positioning_mode,Location_element,Input_content):
self._mongo_p= self.mq._mongo_path()
self.cf.read(self._mongo_p)
db_host = self.cf.get(Positioning_mode, "host")
operation_mr=['delete','select','update','insert']
get_mer=Location_element[0:6]
count_str=Location_element.count('.')
if Location_element and count_str == 2:
get_me_list = Location_element.split('.')
get_method=get_me_list[0]
get_base=get_me_list[1]
get_table=get_me_list[2]
if get_method in operation_mr and get_method and get_base and get_table:
print(get_method)
print(get_base)
print(get_table)
# 连接mongodb 目前只写了集群的连接方法
client = MongoClient(db_host)
# 目标数据库
db=eval("client."+get_base)
# 指定表
collection = eval("db."+get_table)
# 需要select
# Input_content=eval(Input_content)
if Input_content:
if get_method == 'select':
Input_content = eval(Input_content)
for get_select in collection.find(Input_content):
print("查询的数据成功:")
print(get_select)
elif get_method == 'update':
Input_content=eval(Input_content)
# print(Input_content)
get_find_dict=Input_content[0]
get_set_dict=Input_content[1]
collection.update(get_find_dict, {"$set":get_set_dict})
print("数据修改成功")
# collection.update({"userName":"45852488@qq.com"},{"$set":{"code":"1783558010"}})
elif get_method =='insert':
Input_content=eval(Input_content)
if isinstance(Input_content,tuple):
print(type(Input_content))
insert_list=[]
for i in Input_content:
insert_list.append(i)
collection.insert(insert_list)
# print(insert_list)
print("插入数据成功")
else:
collection.insert(Input_content)
print("插入数据成功")
elif get_method =='delete':
print('delete')
Input_content=eval(Input_content)
if isinstance(Input_content,tuple):
for get_del_data in Input_content:
collection.remove(get_del_data)
print("数据已删除")
else:
print("非t")
collection.remove(Input_content)
else:
print("操作关键字或数据库或表填写格式有误")
else:
print("操作关键字或数据库或表填写格式有误")
调用上面的方法增删改查
"""
#参数解释
Positioning_mode 对应配置文件[base_test],连接指定的mongodb
Location_element 参数格式: 操作方法.数据库.表
Input_content 增删该查的条件,mongo都是以字典的形式
""" # 删除数据
# Database().db_mongo('base_test','delete.mydb.email','{"userName" : "1435117266@qq.com"},{"userName" : "1435117288@qq.com"}')
#
# 插数据,多个或单个
# Database().db_mongo('base_test','insert.mydb.email','{"userName":"1435117288@qq.com","code" : "9999999999"},{"userName":"1435117266@qq.com","code" : "99999999999"}')
#
# 查询
# Database().db_mongo('base_test','select.mydb.email','{"userName":"45852488@qq.com"}')
#
#
# 修改
# Database().db_mongo('base_test','update.mydb.email','{"userName":"45852488@qq.com"},{"code":"1783558010","success":True}')
#
# {"code":"9999999999"}
#
python连接集群mongodb,封装增删改查的更多相关文章
- python操作三大主流数据库(8)python操作mongodb数据库②python使用pymongo操作mongodb的增删改查
python操作mongodb数据库②python使用pymongo操作mongodb的增删改查 文档http://api.mongodb.com/python/current/api/index.h ...
- python连接sqlserver和MySQL实现增删改查
参考python核心编程 编写一个用户洗牌的脚本,根据用户输入,选择连接sqlserver或者MySQL,创建数据库.表,随机生成数据,并实现增删改查. 其中,为了兼容python2和python3, ...
- python连接sql server数据库实现增删改查
简述 python连接微软的sql server数据库用的第三方模块叫做pymssql(document:http://www.pymssql.org/en/stable/index.html).在官 ...
- Java连接MongoDB进行增删改查
1.导入必须的包: 详情看项目:http://pan.baidu.com/s/1cvDAOY 2.通过Myeclipse创建WEB项目 3. 3.bean:创建实体类 package com.bean ...
- python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)
一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...
- Scala对MongoDB的增删改查操作
=========================================== 原文链接: Scala对MongoDB的增删改查操作 转载请注明出处! ==================== ...
- MongoDB的增删改查 转
MongoDB的增删改查 (黎明你好原创作品,转载请注明) MongoDB中数据的基本单元叫做文档,采用json的键-值的方式.多个键及其关联的值有序的存放在一起变是文档.类似于编程语言中的键值关系. ...
- Java实现mongodb原生增删改查语句
Java实现mongodb原生增删改查语句 2018-03-16 自动化测试时,需校验数据库数据,为了快速自动化,在代码中用原生增删改查语句操作mongodb 结构 代码 0 pom.xml < ...
- C# 对MongoDB 进行增删改查的简单操作
C# 对MongoDB 进行增删改查的简单操作 下面演示下C#操作MongoDB驱动的简单的增删改查代码 运用到的MongoDB支持的C#驱动,当前版本为1.6.0 1,连接数据库 /// & ...
随机推荐
- Python - Context Manager 上下文管理器
什么是上下文管理器 官方解释... 上下文管理器是一个对象 它定义了在执行 with 语句时要建立的运行时上下文 上下文管理器处理进入和退出所需的运行时上下文以执行代码块 上下文管理器通常使用 wit ...
- P7295-[USACO21JAN]Paint by Letters P【平面图欧拉公式】
正题 题目链接:https://www.luogu.com.cn/problem/P7295 题目大意 给出\(n*m\)的网格,每个格子上有字母,相同字母的四联通相邻格子为连通,每次询问一个子矩阵求 ...
- P5369-[PKUSC2018]最大前缀和【状压dp】
正题 题目链接:https://www.luogu.com.cn/problem/P5369 题目大意 一个数列\(a\)的权值定义为\(max\{\sum_{i=1}^ka_i\}(k\in[1,n ...
- Redis 高可用篇:你管这叫主从架构数据同步原理?
在<Redis 核心篇:唯快不破的秘密>中,「码哥」揭秘了 Redis 五大数据类型底层的数据结构.IO 模型.线程模型.渐进式 rehash 掌握了 Redis 快的本质原因. 接着,在 ...
- 纯代码实现wordpress图片本地化【5.2.2版本可用】
最近用wordpress做了个网站,想复制些新闻过来用,但图片是别人的,就想怎么本地化,在网找到了方法,那就保存一下方法. 复制下面的代码,然后粘贴到你当前WordPress主题的模版函数(funct ...
- NOIP 模拟五 考试总结
T1string T1开的不错,看到这个题很激动,类似与HEOI2016排序,好像还要更简单一些,于是迅速冲了个桶排.因为洛谷上排序那道题是用桶排水的,所以我觉得没必要打线段树了,极端大数据20秒冲过 ...
- 关于VS中的无法解析的外部符号问题
利用caffe的源码编译出的caffe.lib静态链接库里面就包含了源码里面的那些函数的接口i,所以如果在程序中使用的是源码的话,就不需要在链接器里面再添加此静态链接库了 对于无法解析的外部符号,首先 ...
- VS2013编译报错——error LNK2001: 无法解析的外部符号 __imp_PathMatchSpecA E:\CaffeProgram\3train_mnist(p)\3train_mnist\gflags.lib(gflags.obj) 3train_mnist
解决方案来自http://blog.csdn.net/yang6464158/article/details/41743641 感谢感谢~~
- HPE ProLiant 系列服务器Microsoft Windows 2008 R2系统下网卡绑定方法
HPE Network Configuration Utility(以下简称NCU) 网卡绑定工具,用户可以通过该工具很方便的把服务器的多个网卡捆绑到一起以达到容错和增加可用带宽的目的. 1.打开NC ...
- 字符串编码js第三方类库text-encoding
GITHUB地址:https://github.com/BCode001/text-encoding