实验目的:
-
会用Python开发MongoDB的应用程序
-
能够把Python GUI文本框的内容保存到MongoDB中
-
能够把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/
格式要求:
-
MD5为32位
-
日志格式:
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字段的内容显示到界面上。
界面要求:
-
查询条件下拉框,选项“转换成功(info)”,“转换失败(error)”
-
查询结果显示栏: “转换后结果”,“转换日期”
动作要求:
按下【查询】按钮后,查询MongoDB中满足条件的文档,把查询结果显示到界面上
实验要求:
-
提交代码
-
提交执行结果截图
-
提交电子版实验报告
题目一
#!/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()
结果
最后,不足之处还望各位大佬们多多指教!