Python教程

使用Python和MongoDB开发字符转换MD5工具识

本文主要是介绍使用Python和MongoDB开发字符转换MD5工具识,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

实验目的:

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

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

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

实验内容:

题目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中满足条件的文档,把查询结果显示到界面上

实验要求

  1. 提交代码

  2. 提交执行结果截图

  3. 提交电子版实验报告

题目一

#!/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("\n","").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) + "\n"      #换行
        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("\n", "")
        output=self.result_data_Text.get(1.0, END).strip().replace("\n", "")
        time=self.get_current_time()
        result="str_trans_to_md5 success"
        log=self.log_data_Text.get(1.0, END).strip().replace("\n", "")
        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()

界面如下图
界面

查看数据库,插入成功
结果

题目二

说明:实际上,在进行MD5字符转换时很少出现转换失败的情况,所以几乎不存在插入失败的记录,对此,我伪造了一次插入记录

"input" : "error_input", "output" : "error_output", "time" : "2077-11-11 11:11:11", "result" : "str_trans_to_md5 failed", "log" : "2021-11-05 13:39:08 INFO:str_trans_to_md5 failed"

查询文档记录,如下:
查询记录

题目二代码:

#!/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()

结果
结果1
结果2
最后,不足之处还望各位大佬们多多指教!

这篇关于使用Python和MongoDB开发字符转换MD5工具识的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!