ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

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

2021-11-06 13:05:45  阅读:150  来源: 互联网

标签:name Python MongoDB self init window Text data 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
最后,不足之处还望各位大佬们多多指教!

标签:name,Python,MongoDB,self,init,window,Text,data,MD5
来源: https://blog.csdn.net/qq_45813040/article/details/121177316

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有