Python_电子词典

2023-10-15 00:32
文章标签 python 电子词典

本文主要是介绍Python_电子词典,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

功能说明:

  • 用户可注册用户,要求用户名不能重复
  • 用户登陆后可查询单词,查询历史记录,清空历史记录

数据库结构:

  • word表 保存单词及解释
CREATE TABLE `words` (`id` int(11) NOT NULL AUTO_INCREMENT,`word` char(30) DEFAULT NULL,`mean` text,PRIMARY KEY (`id`)
) 
  • user表 保存用户名和密码
CREATE TABLE `user` (`id` int(11) NOT NULL AUTO_INCREMENT,`name` varchar(30) NOT NULL,`passwd` char(64) NOT NULL,PRIMARY KEY (`id`)
) 
  • hist表 保存历史记录
CREATE TABLE `hist` (`id` int(11) NOT NULL AUTO_INCREMENT,`name` varchar(30) DEFAULT NULL,`word` varchar(30) DEFAULT NULL,`time` datetime DEFAULT CURRENT_TIMESTAMP,PRIMARY KEY (`id`)
)

客户端

"""客户端
"""
# 导入相关模块
from socket import *
import sys# 绑定服务端地址
HOST = "127.0.0.1"
PORT = 8888
ADDR = (HOST, PORT)# 发送查询单词请求
def do_query(s):# 循环查询单词while True:word = input("=========输入##退出查询========\n查询单词:")if word == "##":breakmsg = "Q %s" % words.send(msg.encode())# 等待结果并处理data = s.recv(1024).decode()print(data)# 发送查询历史请求
def do_history(s):s.send(b"H")# 等待结果并处理data = s.recv(1024).decode()print(data)# 发送清空历史请求
def clear_history(s):s.send(b"C")# 等待结果并处理feedback = s.recv(1024).decode()if feedback == "OK":print("已清空查询历史!")else:print("发生错误!")# 二级界面
def second_view(s):# 二级界面循环while True:print("=================查询==================")print("1:查单词  2:查历史   3:清历史 4:注销")print("=======================================")cmd2 = input(">>>")if cmd2 == "1":do_query(s)elif cmd2 == "2":do_history(s)elif cmd2 == "3":clear_history(s)elif cmd2 == "4":returnelse:print("输入错误!")# 发送注册请求
def do_register(s):print("==============注册================")name = input("输入用户名:")passwd = input("输入密码:")print("==================================")msg = "R %s %s" % (name, passwd)s.send(msg.encode())# 等待结果并处理data = s.recv(1024).decode()if data == "OK":print("注册成功!")# 进入二级界面second_view(s)else:print("用户名重复!")# 发送登录请求
def do_login(s):print("==============登录================")name = input("输入用户名:")passwd = input("输入密码:")print("==================================")msg = "L %s %s" % (name, passwd)s.send(msg.encode())# 等待结果并处理data = s.recv(1024).decode()if data == "OK":print("登录成功!")# 进入二级界面second_view(s)else:print("登录失败!")# 主程序
def main():# 连接服务端s = socket()s.connect(ADDR)# 一级界面循环while True:print("==============Welcome================")print("R:注册       L:登录           E:退出")print("=====================================")cmd1 = input(">>>")if cmd1 == "R":do_register(s)elif cmd1 == "L":do_login(s)elif cmd1 == "E":s.send(b"E")sys.exit("程序退出!")else:print("输入错误!")if __name__ == '__main__':main()

服务端

"""服务端
"""
# 导入相关模块
from socket import *
from multiprocessing import Process
import signal
from dict_db import Database# 绑定服务端地址
HOST = "127.0.0.1"
PORT = 8888
ADDR = (HOST, PORT)
# 创建操作数据库对象
db = Database()# 处理注册请求
def deal_register(c, name, passwd):if db.register(name, passwd):c.send(b"OK")else:c.send(b"Not OK")# 处理登录请求
def deal_login(c, name, passwd):if db.login(name, passwd):c.send(b"OK")else:c.send(b"Not OK")# 处理查单词请求
def deal_query(c, word):res = db.query(word)c.send(res.encode())# 处理查历史请求
def deal_history(c):res_tuple = db.history()if not res_tuple:c.send("无查询历史!".encode())else:res = ""for i in res_tuple:res += "%s,%s,%s\n" % (i[0], i[1], i[2])c.send(res.encode())# 处理清空历史请求
def deal_clear_history(c):if db.clear_history():c.send(b"OK")else:c.send(b"Not OK")# 子进程主程序
def handle(c):# 创建游标db.create_cursor()while True:data = c.recv(1024).decode()if not data or data == "E":returncmd = data.split(" ", 2)if cmd[0] == "R":deal_register(c, cmd[1], cmd[2])elif cmd[0] == "L":deal_login(c, cmd[1], cmd[2])elif cmd[0] == "Q":deal_query(c, cmd[1])elif cmd[0] == "H":deal_history(c)elif cmd[0] == "C":deal_clear_history(c)# 主程序
def main():# 创建监听套接字s = socket()s.bind(ADDR)s.listen(5)# 处理僵尸进程signal.signal(signal.SIGCHLD, signal.SIG_IGN)# 循环创建多个子进程while True:c, addr = s.accept()p = Process(target=handle, args=(c,))p.start()if __name__ == '__main__':main()

操作数据库模块

"""数据库处理
"""
# 导入pymysql模块
import pymysql# 创建Database类
class Database:def __init__(self):self.host = 'localhost'self.port = 3306self.user = "root"self.password = "123456"self.database = "dict"self.charset = "utf8"# 初始化创建db对象self.__connect_database()# 初始化name属性,查询历史,清空历史使用self.name = Nonedef __connect_database(self):"""创建db属性"""self.db = pymysql.connect(host=self.host,port=self.port,user=self.user,password=self.password,database=self.database,charset=self.charset)def create_cursor(self):"""创建游标属性"""self.cur = self.db.cursor()def register(self, name, passwd):"""注册方法,如果name存在,返回False,不存在则插入user表,返回True,过程出错返回False"""sql = "select name from user where name=%s;"self.cur.execute(sql, [name])r = self.cur.fetchone()if r:return Falseelse:try:sql = "insert into user (name,passwd) VALUES (%s,%s);"self.cur.execute(sql, [name, passwd])self.db.commit()self.name = namereturn Trueexcept:self.db.rollback()return Falsedef login(self, name, passwd):"""登录方法,用户不存在,返回False,存在但密码不正确,返回False,正确返回True"""sql = "select passwd from user where name=%s;"self.cur.execute(sql, [name])r = self.cur.fetchone()if r:if r[0] == passwd:self.name = namereturn Trueelse:return Falseelse:return Falsedef query(self, word):"""查询单词,查不到单词也写入hist且返回错误,查到单词返回解释,过程错误返回错误"""sql = "select mean from words where word=%s;"self.cur.execute(sql, [word])r = self.cur.fetchone()if not r:try:sql = "insert into hist (name,word) VALUES (%s,%s);"self.cur.execute(sql, [self.name, word])self.db.commit()except:self.db.rollback()return "查询错误"else:try:sql = "insert into hist (name,word) VALUES (%s,%s);"self.cur.execute(sql, [self.name, word])self.db.commit()return r[0]except:self.db.rollback()return "查询错误"def history(self):"""查询历史,查不到返回False,查到返回结果二维元组"""sql = "select name,word,time from hist where name =%s ORDER BY time DESC limit 10;"self.cur.execute(sql, [self.name])res = self.cur.fetchall()if not res:return Falseelse:return resdef clear_history(self):"""清空历史,清空返回True,失败返回False:return:"""try:sql = "delete from hist where name=%s;"self.cur.execute(sql, [self.name])self.db.commit()return Trueexcept:self.db.rollback()return False

阶段代码 on 29/2/2020

这篇关于Python_电子词典的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/214179

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e