非关系型数据库:使用Python和MongoDB开发字符转换MD5工具

目录

实验目的和要求

实验目的:

要求:

实验环境

实验内容与过程

1、实验内容

2、关键代码

3、流程图

实验结果与分析

实验结果

结果分析:

实验心得


实验目的和要求

实验目的:

1. 会用Python开发MongoDB的应用程序

2. 能够把Python GUI文本框的内容保存到MongoDB中

3. 能够把MongoDB中的数据显示到Python GUI上

要求:

1. 提交代码

2. 提交执行结果截图

3. 提交电子版实验报告

实验环境

操作系统:Windows11

Mongodb 

实验内容与过程

1、实验内容

题目1:把Python GUI画面中的内容存放到MongoDB中

使用Python做一个把字符串转换成MD5的桌面应用,把变换前的数据、变换结果和日志存放到MongoDB中

界面要求:

1.待处理数据入力框

2.结果输出框

3.日志输输出框

动作要求:

按下【字符串转换MD5】按钮后

1.GUI界面的【输出结果】栏显示变换后结果

2.GUI界面的【日志】栏显示变换结果

3.待处理数据、输入结果、日志保存到MongoDB数据库中

MD5:https://md5jiami.51240.com/

格式要求:

1.  MD5为32位

2.  日志格式:

2020-10-07 14:44:13 INFO:str_trans_to_md5 success

2020-10-0714:46:39 ERROR:str_trans_to_md5 failed

数据保存要求:

“input”:””, ”output”:””, “time” :””, ”result”:””,  ”log”: ””

题目2:把MongoDB中的数据显示到PythonGUI界面中

使用Python做一个GUI界面,查询条件为result,然后把满足条件的文档的output和time字段的内容显示到界面上。

界面要求:

1.   查询条件下拉框,选项“转换成功(info)”,“转换失败(error)”

2.   查询结果显示栏:  “转换后结果”,“转换日期”

动作要求:

按下【查询】按钮后,查询MongoDB中满足条件的文档,把查询结果显示到界面上

2、关键代码

#!/usr/bin/env python
# -*- coding: utf-8 -*-

from tkinter import *
import hashlib
import time
import pymongo

myclient = pymongo.MongoClient("mongodb://localhost:27017")  # Host以及port
db = myclient["mydb"]
coll = db["md5"]
LOG_LINE_NUM = 0

class MY_GUI():
    def __init__(self,init_window_name):
        self.init_window_name = init_window_name

    #设置窗口
    def set_init_window(self):
        # 窗口名
        self.init_window_name.title("文本处理工具_v1.2")
        # 1068 681为窗口大小,+10 +10 定义窗口弹出时的默认展示位置
        self.init_window_name.geometry('1068x681+10+10')

        # 设置窗口背景色,其他背景色见
        # self.init_window_name["bg"] = "blue"

        # 虚化,值越小虚化程度越高
        # self.init_window_name.attributes("-alpha",0.9)

        #标签
        self.init_data_label = Label(self.init_window_name, text="待处理数据")
        self.init_data_label.grid(row=0, column=0)
        self.result_data_label = Label(self.init_window_name, text="输出结果")
        self.result_data_label.grid(row=0, column=12)
        self.log_label = Label(self.init_window_name, text="日志")
        self.log_label.grid(row=12, column=0)

        #文本框
        # 原始数据录入框
        self.init_data_Text = Text(self.init_window_name, width=67, height=35)
        self.init_data_Text.grid(row=1, column=0, rowspan=10, columnspan=10)

        # 处理结果展示
        self.result_data_Text = Text(self.init_window_name, width=70, height=49)
        self.result_data_Text.grid(row=1, column=12, rowspan=15, columnspan=10)

        # 日志框
        self.log_data_Text = Text(self.init_window_name, width=66, height=9)
        self.log_data_Text.grid(row=13, column=0, columnspan=10)

        #按钮
        # 调用内部方法  加()为直接调用
        self.str_trans_to_md5_button = Button(self.init_window_name, text="字符串转MD5", bg="lightblue", width=10,command=self.str_trans_to_md5)
        self.str_trans_to_md5_button.grid(row=1, column=11)


    #功能函数
    def str_trans_to_md5(self):
        src = self.init_data_Text.get(1.0,END).strip().replace("
","").encode()
        if src:
            try:
                myMd5 = hashlib.md5()
                myMd5.update(src)
                myMd5_Digest = myMd5.hexdigest()

                #输出到界面
                self.result_data_Text.delete(1.0,END)
                self.result_data_Text.insert(1.0,myMd5_Digest)
                self.write_log_to_Text("INFO:str_trans_to_md5 success")
                self.writeToMongoDB()
            except:
                self.result_data_Text.delete(1.0,END)
                self.result_data_Text.insert(1.0,"字符串转MD5失败")
        else:
            self.write_log_to_Text("ERROR:str_trans_to_md5 failed")

    #获取当前时间
    def get_current_time(self):
        current_time = time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))
        return current_time

    #日志动态打印
    def write_log_to_Text(self,logmsg):
        global LOG_LINE_NUM
        current_time = self.get_current_time()
        logmsg_in = str(current_time) +" " + str(logmsg) + "
"      #换行
        if LOG_LINE_NUM <= 7:
            self.log_data_Text.insert(END, logmsg_in)
            LOG_LINE_NUM = LOG_LINE_NUM + 1
        else:
            self.log_data_Text.delete(1.0,2.0)
            self.log_data_Text.insert(END, logmsg_in)
    #写入数据库
    def writeToMongoDB(self):
        #输出格式要求 "input":"","output":"",“time”:"","result":"","log:""
        input=self.init_data_Text.get(1.0, END).strip().replace("
", "")
        output=self.result_data_Text.get(1.0, END).strip().replace("
", "")
        time=self.get_current_time()
        result="str_trans_to_md5 success"
        log=self.log_data_Text.get(1.0, END).strip().replace("
", "")
        dict={"input":input,"output":output,"time":time,"result":result,"log":log}
        x = coll.insert_one(dict)

def gui_start():

    # 实例化出一个父窗口
    init_window = Tk()
    ZMJ_PORTAL = MY_GUI(init_window)

    # 设置根窗口默认属性
    ZMJ_PORTAL.set_init_window()

    # 父窗口进入事件循环,可以理解为保持窗口运行,否则界面不展示
    init_window.mainloop()

gui_start()
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import tkinter
import tkinter as tk
from tkinter import ttk
from tkinter import *
import hashlib
import time
import pymongo

myclient = pymongo.MongoClient("mongodb://localhost:27017")  # Host以及port
db = myclient["mydb"]
coll = db["md5"]
LOG_LINE_NUM = 0
class MY_GUI():
    def __init__(self,init_window_name):
        self.init_window_name = init_window_name
    #设置窗口
    def set_init_window(self):
        # 窗口名
        self.init_window_name.title("文本处理工具_v1.2")
        # 1068 681为窗口大小,+10 +10 定义窗口弹出时的默认展示位置
        self.init_window_name.geometry('1068x681+10+10')
        # 设置窗口背景色,其他背景色见
        # self.init_window_name["bg"] = "blue"

        # 虚化,值越小虚化程度越高
        # self.init_window_name.attributes("-alpha",0.9)

        #标签
        self.init_data_label = Label(self.init_window_name, text="查询条件")
        self.init_data_label.grid(row=0, column=2)
        self.result_data_label = Label(self.init_window_name, text="转换后结果")
        self.result_data_label.grid(row=0, column=12)
        self.time_data_label = Label(self.init_window_name, text="转换时间")
        self.time_data_label.grid(row=0, column=20)

        #下来菜单
        xVariable = StringVar()
        self.select_ttk = ttk.Combobox(self.init_window_name, textvariable=xVariable)
        self.select_ttk["value"]=("转换成功(info)", "装换失败(error)")
        self.select_ttk.current(0)
        self.select_ttk.grid(row=1, column=2)
        # 处理结果展示--转换后结果
        #self.result_data_Text = Text(self.init_window_name, width=70, height=50)
        #self.result_data_Text.grid(row=1, column=12, rowspan=5, columnspan=10)
        self.result_data_Text = Text(self.init_window_name, width=30, height=30)
        self.result_data_Text.grid(row=1, column=12)
        # 处理结果展示--转换时间
        self.time_data_Text = Text(self.init_window_name, width=30, height=30)
        self.time_data_Text.grid(row=1, column=20)
        #按钮

        # 调用内部方法  加()为直接调用
        self.selectFromMongoDB_button = Button(self.init_window_name, text="查询", bg="lightblue", width=10,command=self.selectFromMongoDB)
        self.selectFromMongoDB_button.grid(row=1, column=11)


    #功能函数
    def selectFromMongoDB(self):
        re=self.select_ttk.get()
        self.result_data_Text.delete(1.0, tkinter.END)
        self.time_data_Text.delete(1.0, tkinter.END)#每次清楚文本内容
        if re=="转换成功(info)":
            myquery = {"result": "str_trans_to_md5 success"}
            mytarget1 = {"_id": 0, "output": 1}
            mytarget2 = {"_id": 0, "time": 1}
            for x in coll.find(myquery, mytarget1):
                self.result_data_Text.insert('insert',x)
            for y in coll.find(myquery, mytarget2):
                self.time_data_Text.insert('insert',y)
        if re=="装换失败(error)":
            myquery = {"result": "str_trans_to_md5 failed"}
            mytarget1 = {"_id": 0, "output": 1}
            mytarget2 = {"_id": 0, "time": 1}
            for x in coll.find(myquery, mytarget1):
                self.result_data_Text.insert('insert', x)
            for y in coll.find(myquery, mytarget2):
                self.time_data_Text.insert('insert', y)

def gui_start():
    # 实例化出一个父窗口
    init_window = Tk()
ZMJ_PORTAL = MY_GUI(init_window)

    # 设置根窗口默认属性
ZMJ_PORTAL.set_init_window()

    # 父窗口进入事件循环,可以理解为保持窗口运行,否则界面不展示
    init_window.mainloop()
gui_start()

3、流程图

 

实验结果与分析

实验结果

 

 

 

结果分析:

实验结果与预期相符,实验成功。

实验一中我输入了mongodb进行字符串转MD5,结果为8b9743284bb8763d87acf0410344dcf0,时间为2023-12-03 09:42:11 INFO:str_trans_to_md5 success,转换成功,在实验二中进行检测,查询成功的可以看到输出了刚刚转换成功的结果8b9743284bb8763d87acf0410344dcf0,还有时间2023-12-03 09:42:11,再查询失败的因为没有失败的,所以没有输出错误结果。 

实验心得

在完成这个实验的过程中,我学到了很多关于Python GUI编程和MongoDB的知识。通过使用tkinter库,我学会了如何创建GUI界面,包括输入框、输出框、按钮等组件的创建和布局。这让我能够创建一个用户友好的界面,提供方便的操作和良好的用户体验。了解了MD5加密算法的原理,并使用Python内置的hashlib库进行了字符串的MD5转换。MD5算法可以将任意长度的字符串转换为固定长度的32位哈希值,保证了数据的唯一性和安全性。学习了如何使用Python的pymongo库连接和操作MongoDB数据库。我创建了一个数据库和集合,并学会了如何使用insert_one()方法将数据插入到MongoDB中。在实验中,我使用了日志记录来追踪应用程序的运行情况。通过将日志存储到MongoDB中,我可以方便地查看和分析应用程序的运行历史。在实验中,我学会了如何使用messagebox库来显示错误消息框,并通过条件语句检查输入是否为空或操作是否成功。这样可以提高应用程序的稳定性和用户体验。完成这个实验让我对Python GUI编程和MongoDB有了更深入的了解。我学会了如何创建一个功能完善的GUI应用程序,并将数据存储到数据库中。这个实验对我进一步提升了Python编程和数据库操作的能力,为我今后的学习和工作奠定了很好的基础。 

© 版权声明
THE END
如果内容对您有所帮助,就支持一下吧!
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容