目录
实验目的和要求
实验目的:
要求:
实验环境
实验内容与过程
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编程和数据库操作的能力,为我今后的学习和工作奠定了很好的基础。
暂无评论内容