dictionary小项目代码管理
Posted alan-song
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了dictionary小项目代码管理相关的知识,希望对你有一定的参考价值。
软件项目开发流程
需求分析 ----》 概要设计 ---》 项目计划 ----》详细设计---》编码测试 -----》
项目测试 ----》调试修改 ---》项目发布----》后期维护
>需求分析 : 确定用户的真实需求
>>1. 确定用户的真实需求,项目的基本功能
>>2. 确定项目的整体难度和可行性分析
>>3. 需求分析文档,用户确认
>概要设计:对项目进行初步分析和整体设计
>>1. 确定功能模块
>>2. 进行可行性分析 搭建整体架构图
>>3. 确定技术思路和使用框架
>>4. 形成概要文档指导开发流程
>项目计划 : 确定项目开发的时间轴和流程
>>1. 确定开发工作的先后顺序
>>2. 确定时间轴 ,事件里程碑
>>3. 人员分工
>>4. 形成甘特图和思维导图等辅助内容
>详细设计 : 项目的具体实现
>>1.形成详细设计文档 : 思路,逻辑流程,功能说明,技术点说明,数据结构说明,代码说明
>编码测试 : 按照预定计划实现代码编写,并且做基本检测
>>1. 代码编写
>>2. 写测试程序
>>3. 技术攻关
>项目测试 : 对项目按照功能进行测试
>>1. 跨平台测试 ,使用测试
>>2. 根据测试报告进行代码修改
>>3. 完成测试报告
>项目发布
>>1.项目交付用户进行发布
>>2.编写项目说明文档
>后期维护
>>1.维护项目正常运转
>>2.进行项目的迭代升级
功能说明
>用户可以登录和注册
* 登录凭借用户名和密码登录
* 注册要求用户必须填写用户名,密码,其他内容自定
* 用户名要求不能重复
* 要求用户信息能够长期保存
>可以通过基本的图形界面print以提示客户端输入。
* 程序分为服务端和客户端两部分
* 客户端通过print打印简单界面输入命令发起请求
* 服务端主要负责逻辑数据处理
* 启动服务端后应该能满足多个客户端同时操作
>客户端启动后即进入一级界面,包含如下功能:登录 注册 退出
* 退出后即退出该软件
* 登录成功即进入二级界面,失败回到一级界面
* 注册成功可以回到一级界面继续登录,也可以直接用注册用户进入二级界面
>用户登录后进入二级界面,功能如下:查单词 历史记录 注销
* 选择注销则回到一级界面
* 查单词:循环输入单词,得到单词解释,输入特殊符号退出单词查询状态
* 历史记录:查询当前用户的查词记录,要求记录包含name word time。可以查看所有记录或者前10条均可。
>单词本说明
>>每个单词一定占一行
>>单词按照从小到大顺序排列
>>单词和解释之间一定有空格
>查词说明
>>直接使用单词本查询(文本操作)
>>先将单词存入数据库,然后通过数据库查询。(数据库操作)
技术方案
* tcp 套接字
* 多进程 并发
* 历史记录 : 前10条
* 注册成功 直接登录
将单词本存入数据表mysql
1. 创建数据库 dict (utf8)
2. 创建数据表 words 将单词和单词解释分别存入不同的字段
3. 将单词存入words单词表 超过 19500 即可
数据表进行建立
*单词数据库
create database dictionary charset=utf8;
*单词数据表 words -> id word mean
create table (id int primary key auto_incremant, word varchar(32),mean text);
* 用户 user -> id name passwd
create table user (id int primary key auto_increment,name varchar(32) not null,passwd varchar(128) not null);
* 历史记录 hist-> id name word time
create table hist (id int primary key auto_increment,name varchar(32) not null, word varchar(28) not null,time datetime default now() );
单词表的插入
1 import pymysql 2 import re 3 4 f = open(‘dictionary.txt‘) 5 db = pymysql.connect(host = ‘localhost‘, 6 port = 3306, 7 user = ‘root‘, 8 password = ‘123456‘, 9 database = ‘dictionary‘, 10 charset = ‘utf8‘) 11 #创建游标 12 cur = db.cursor() 13 #执行插入语句 14 sql = "insert into words (word,mean) values (%s ,%s)" 15 16 for line in f: 17 #元祖 非空字符,匹配中间的空格,有些存在无解释 18 tup = re.findall(r‘(\S+)\s+(.*)‘,line)[0] 19 try: 20 cur.execute(sql,tup)#游标方法 21 db.commit()#执行写操作需要提交 22 except: 23 db.rollback() 24 25 f.close() 26 cur.close() 27 db.close()
结构设计
几个模块 封装设计
客户端 :
服务端 : 逻辑请求处理 , 数据库操作处理
函数封装: 直接写一个功能程序提供给使用者使用。使用者直接运行,而不是需要使用我的代码的某一部分。
功能分析 和 通信搭建
并发通信 登录 注册 查单词 历史记录 退出 返回上一级界面
罗列功能逻辑 :每个功能确定服务端和客户端该做什么,编写代码测试
注册 客户端: 输入注册信息
发送请求
得到反馈
服务端 : 接收请求
判断是否允许注册
允许注册将信息存入数据库
给客户端反馈结果
登录 客户端: 输入用户名密码
发送请求给服务器
得到服务器反馈
服务端: 接收请求
判断是否允许登录
发送结果
查单词 客户端: 输入单词
发送请求 Q name word
等待接收结果
服务端: 接收请求
查找单词
发送结果
插入历史记录
设定客户端服务端协议
以上是关于dictionary小项目代码管理的主要内容,如果未能解决你的问题,请参考以下文章