孤荷凌寒自学python第六十三天学习mongoDB的基本操作并进行简单封装2

(完整学习过程屏幕记录视频地址在文末)

今天是学习mongoDB数据库的第九天。

今天继续学习mongoDB的简单操作,并继续对一些可能反复经常使用的操作进行简单的封装。

今天成功了解并实测完成了从mongoDB数据库中筛选出记录的操作,详细学习过程见屏幕录屏学习过程。

测试代码如下:

【ceshi.py】

```

from pymongo import MongoClient

import datetime

import _mty

import _mf

import _mre

import _cl

import _mmongo

def msgbox(info,titletext='孤荷凌寒的对话框QQ578652607',style=0,isShowErrMsg=False):

return _mty.msgboxGhlh(info,titletext,style,isShowErrMsg)

def thirdConnect():

#--获取授权用户和密码:

#stru=_mf.readAllTextFromTxtFileGhlh('u.txt')

#strp=_mf.readAllTextFromTxtFileGhlh('p.txt')

#得到连接对象

client=_mmongo.conMongoDb("localhost")

#-- 获取数据库的命名标识

db=client.ghlhsecond

#--获取其中的一个集合对象

jh=db.onejh

#----添加记录

dicA={

u'姓名':u'张三2',

u'性别':u'男',

u'年龄':36,

u'婚否':True

}

dicB={

u'姓名':u'李四2',

u'性别':u'女',

u'年龄':32,

u'婚否':False

}

lstA=[dicA,dicB]

#------

#isok=_mmongo.addNewData(jh,lstA)

#msgbox(str(isok))

#--查询这个集合其中的记录

#data=jh.find()

#for i in data:

#    msgbox(str(i))

data=_mmongo.findData(jh,'姓名','/张三./','=',True,True)

print(data)

for i in data:

msgbox(str(i))

thirdConnect()

```

今天修改了自定义的模块中存放自己简单封装的一些函数等:

【_mmongo.py】

```

#!/usr/bin/env python3

# -*- coding: utf-8 -*-

#此模块用于封闭mongodb数据库操作的一些方法

import string

import pymongo

import _mty

import _cl #常用常量模块

import _mre

mmongoErrString='' #供其它模块使用的全局变量了,实时保存了各函数执行时的错误信息

def msgbox(info,titletext='孤荷凌寒的mongodb模块对话框QQ578652607',style=0,isShowErrMsg=False):

return _mty.msgboxGhlh(info,titletext,style,isShowErrMsg)

#获取一个针对mongodb数据库服务的client对象的方法函数

def conMongoDb(serveraddress,strusername='',strpassword='',strauthMechanism='SCRAM-SHA-1',isconnect=False,isShowMsg=False):

'''

根据传递进函数的mongoDB数据服务器地址来连接,并返回一个client对象

'''

try:

client=None

if strusername=='' or strpassword=='':

#无验证连接方式:

client=pymongo.MongoClient(serveraddress)

else:

#有验证的连接:

client=pymongo.MongoClient(serveraddress,username=strusername,password=strpassword,authMechanism=strauthMechanism,connect=isconnect)

#-----------------------------------

return client

except Exception as e:

mmongoErrString='连接MongoDB数据库【' + serveraddress + '】时出错:' + str(e) + '\n此函数由【孤荷凌寒】创建,QQ578652607'

if isShowMsg==True:

msgbox(mmongoErrString)

return None

else:

pass

finally:

pass

#向指定的集合中添加记录

def addNewData(objjh,objdata,isShowMsg=False):

'''

通过指定要添加记录的集合对象和要添加的数据对象(字典或字典组成的列表)来向指定集合添加记录

#objjh 要操作的集合对象

#objdata 要添加的数据,如果传入一个字典对象则是添加一条记录;如果传入一个由多个字典组合成的列表对象,就是同时添加多条记录。

'''

try:

r=objjh.insert(objdata)

if r==None:

return False

else:

return True

except Exception as e:

mmongoErrString='向集合中添加记录时出错:' + str(e) + '\n此函数由【孤荷凌寒】创建,QQ578652607'

if isShowMsg==True:

msgbox(mmongoErrString)

return False

else:

pass

finally:

pass

#简化查询记录的书写----

def findData(objjh,strkeynm,value,strbijiao='',isReturnList=True,isShowMsg=False):

'''

*如果是字符串使用大于小于等比较运算则会被 忽略

*value支持使用正则表达式

'''

try:

if strkeynm=='' or value=='':

mmongoErrString='查询集合中符合指定一个条件的记录时出错:必须指明要筛选的键名和键值\n此函数由【孤荷凌寒】创建,QQ578652607'

if isShowMsg==True:

msgbox(mmongoErrString)

return None

#----------------------------------------------------------

dic=None

if strbijiao=='>':

#--大于比较---------------

dic={strkeynm:{'$gt':value}}

elif strbijiao=='>=':

#--大于等于------

dic={strkeynm:{'$gte':value}}

elif strbijiao=='<':

#---小于--------------

dic={strkeynm:{'$lt':value}}

elif strbijiao=='<=':

#---小于等于--------------

dic={strkeynm:{'$lte':value}}

elif strbijiao=='<>' or strbijiao=='!=':

#---不等于--------------

dic={strkeynm:{'$ne':value}}

elif strbijiao=='in' or strbijiao=='within' or strbijiao=='包含' or strbijiao=='包括':

#---in--------------只包含如字符串的一部分的情况,还不能处理

dic={strkeynm:{'$in':value}}

elif strbijiao=='nin' or strbijiao=='without' or strbijiao=='不包含' or strbijiao=='不包括':

#---不等于--------------

dic={strkeynm:{'$nin':value}}

else:

#===等于

dic={strkeynm:value}

#--------------------------------------------

r=objjh.find(dic)

if r==None:

return None

else:

#---现在得到的是一个生成器

#---进行处理,返回为一个列表(可以在参数中加一个开关,看是否返回为一个列表,或直接返回为生成器)

if isReturnList==False:

return r

else:

#----改成列表后再返回 ====

return list(r)

#---------------------------------------------------------------------------

except Exception as e:

mmongoErrString='查询集合中符合指定一个条件的记录时出错:' + str(e) + '\n此函数由【孤荷凌寒】创建,QQ578652607'

if isShowMsg==True:

msgbox(mmongoErrString)

return None

else:

pass

finally:

pass

```

学习感受:

1.

筛选查询时,大于,小于等针对数值类型的操作,如果用到字符串对象上,会被直接忽略,不现筛选。

2.

那天学习整理的资料中,对各种比较操作的方法不够全面,应当还有更多$符号开始的比较操作识别符号。

3.

今天没有解决针对字符串对象的值时,如果只筛选匹配字符串中的部分内容的处理,但已知道只能使用正则表达式来作为筛选的value ,但没有实验成功。

——————————

今天整理的学习笔记完成,最后例行说明下我的自学思路:

根据过去多年我自学各种编程语言的经历,认为只有真正体验式,解决实际问题式的学习才会有真正的效果,即让学习实际发生。在2004年的时候我开始在一个乡村小学自学电脑 并学习vb6编程语言,没有学习同伴,也没有高师在上,甚至电脑都是孤岛(乡村那时还没有网络),有的只是一本旧书,在痛苦的自学摸索中,我找到适应自己零基础的学习方法:首先是每读书的一小节就作相应的手写笔记,第二步就是上机测试每一个笔记内容是否实现,其中会发现书中讲的其实有出入或错误,第三步就是在上机测试之后,将笔记改为电子版,形成最终的修订好的正确无误的学习笔记 。

通过反复尝试错误,在那个没有分享与交流的黑暗时期我摸黑学会了VB6,尔后接触了其它语言,也曾听过付费视频课程,结果发现也许自己学历果然太低,就算是零基础的入门课程,其实也难以跟上进度,讲师的教学多数出现对初学者的实际情况并不了解的情况,况且学习者的个体也存在差异呢?当然更可怕的是收费课程的价格往往是自己难以承受的。

于是我的所有编程学习都改为了自学,继续自己的三步学习笔记法的学习之路。

当然自学的最大问题是会走那么多的弯路,没有导师直接输入式的教学来得直接,好在网络给我们带来无限搜索的机会,大家在网络上的学习日志带给我们共享交流的机会,而QQ群等交流平台、网络社区的成立,我们可以一起自学,互相批评交流,也可以获得更有效,更自主的自学成果。

于是我以人生已过半的年龄,决定继续我的编程自学之路,开始学习python,只希望与大家共同交流,一个人的独行是可怕的,只有一群人的共同前进才是有希望的。

诚挚期待您的交流分享批评指点!欢迎联系我加入从零开始的自学联盟。

这个时代互联网成为了一种基础设施的存在,于是本来在孤独学习之路上的我们变得不再孤独,因为网络就是一个新的客厅,我们时刻都可以进行沙龙活动。

非常乐意能与大家一起交流自己自学心得和发现,更希望大家能够对我学习过程中的错误给予指点——是的,这样我就能有许多免费的高师了——这也是分享时代,社区时代带来的好福利,我相信大家会的,是吧!

根据完全共享的精神,开源互助的理念,我的个人自学录制过程是全部按4K高清视频录制的,从手写笔记到验证手写笔记的上机操作过程全程录制,但因为4K高清文件太大均超过5G以上,所以无法上传至网络,如有需要可联系我QQ578652607对传,乐意分享。上传分享到百度网盘的只是压缩后的720P的视频。

我的学习过程录像百度盘地址分享如下:(清晰度:1280x720)

链接:https://pan.baidu.com/s/12auPxj7h6J6RglqSEtSuFw

提取码:h95m

Bilibili:

https://www.bilibili.com/video/av40171474/

喜马拉雅语音笔记:

https://www.ximalaya.com/keji/19103006/151392469

转载于:https://www.cnblogs.com/lhghroom/p/10247282.html

孤荷凌寒自学python第六十三天学习mongoDB的基本操作并进行简单封装2相关推荐

  1. 孤荷凌寒自学python第八十一天学习爬取图片1

    孤荷凌寒自学python第八十一天学习爬取图片1 (完整学习过程屏幕记录视频地址在文末) 通过前面十天的学习,我已经基本了解了通过requests模块来与网站服务器进行交互的方法,也知道了Beauti ...

  2. 孤荷凌寒自学python第四十五天Python初学基础基本结束的下阶段预安装准备

    孤荷凌寒自学python第四十五天Python初学基础基本结束的下阶段预安装准备 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 今天本来应当继续学习Python的数据库操作,但根据过去我自学 ...

  3. 孤荷凌寒自学python第四十一天python的线程同步之Event对象

    孤荷凌寒自学python第四十一天python的线程同步之Event对象 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 鉴于Lock锁与RLock锁均宣告没有完全完成同步文件操作的问题,于是 ...

  4. 孤荷凌寒自学python第十四天python代码的书写规范与条件语句及判断条件式

    孤荷凌寒自学python第十四天python代码的书写规范与条件语句及判断条件式 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 在我学习过的所有语言中,对VB系的语言比较喜欢,而对C系和J系 ...

  5. 孤荷凌寒自学python第三十九天python 的线程锁Lock

    孤荷凌寒自学python第三十九天python的线程锁Lock (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 当多个线程同时操作一个文件等需要同时操作某一对象的情况发生时,很有可能发生冲突, ...

  6. 孤荷凌寒自学python第三十八天初识python的线程控制

    孤荷凌寒自学python第三十八天初识python的线程控制 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 一.线程 在操作系统中存在着很多的可执行的应用程序,每个应用程序启动后,就可以看着 ...

  7. 孤荷凌寒自学python第六天 列表的嵌套与列表的主要方法

    孤荷凌寒自学python第六天 列表的嵌套与列表的主要方法 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) (同步的语音笔记朗读:https://www.ximalaya.com/keji/1 ...

  8. 孤荷凌寒自学python第五十四天使用python来删除Firebase数据库中的文档

    孤荷凌寒自学python第五十四天使用python来删除Firebase数据库中的文档 (完整学习过程屏幕记录视频地址在文末) 今天继续研究Firebase数据库,利用google免费提供的这个数据库 ...

  9. python 保存文件 吃内存_孤荷凌寒自学python第三十七天python的文件与内存变量之间的序列化与反序列化...

    孤荷凌寒自学python第三十七天python的文件与内存变量之间的序列化与反序列化 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 一.什么是序列化与反序列化 序列化是指将内存中的数据进行指 ...

最新文章

  1. python换中包_在Linux中替换已安装的python包中的源代码
  2. 递归生成全排列【C/C++】
  3. 初等数论--同余--WILSON定理
  4. sqoop导入-hive
  5. vs 启动调用的目标发生异常_协程中的取消和异常 | 取消操作详解
  6. Android开源源码推荐(一)
  7. C# 调用其他的动态库开发应注意的问题
  8. StringEscapeUtils的资料
  9. Android中ContentProvider组件详解
  10. group by 用法解析_GRE数学专项练习及解析概率
  11. linux驱动怎么判断定时器正在运行,Linux设备驱动编程之定时器
  12. matlab gui怎样将结果保存在excel中_声发射简单使用matlab导入参数波形数据并绘图...
  13. 经济学原理曼昆第八版课后习题答案
  14. 应用程序无法正常启动0xc0150002+vs2005配置opencv2.2.0
  15. 换硬币 (20 分)
  16. 单细胞测序在免疫治疗研究中的应用
  17. 旅游攻略应该怎么做,你做对了吗?
  18. MySQL-7 DDL约束 标识列 TCL事务控制语言 视图view
  19. php 完全前后端分离使用jwt,前后端分离,在 angular 8 中利用 JWT 进行身份认证
  20. 程序员的职业病,一定要注重身体健康才是最重要的

热门文章

  1. 使用xUnit测试验证属性
  2. 微软 Build 2020 为 WSL 带来的新消息一览:WSL2 即将到来,对 GPU 和 Linux GUI 的支持也不远了
  3. Visual Studio 2019 v16.6 Preview 3 发布
  4. 官宣!vue.ant.design 低调上线
  5. panel中html怎么写,在Panel上绘制Html表?
  6. java语言精通能干什么_Java学到什么程度才能叫精通?
  7. ibatis 存储过程 结果集 map_「大数据」(七十五)Spark之弹性分布式数据集
  8. c语言成绩管理系统不用结构体,不用指针链表和结构体数组怎么编学生成绩管理系统啊...
  9. java雪崩_【并发编程】java 如何解决redis缓存穿透、缓存雪崩(高性能示例代码)...
  10. 简单的动态网站java,Java实践:一个简单的动态数组实现