ImageVerifierCode 换一换
格式:DOCX , 页数:38 ,大小:457.48KB ,
资源ID:28333376      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/28333376.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(delphi题库系统设计与实现论文.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

delphi题库系统设计与实现论文.docx

1、delphi题库系统设计与实现论文摘要一般情况教师想出一份试卷,要么到庞大的题库里一道一道的把题找出来,或是从几本相关的书里把题一道一道挑出来。这样即费时又费力,而且很难保证试题的覆盖面和把握好试卷的难度。正是为了能够帮助教师轻松的出一份高质量的试卷而开发了本软件。为了达到预期的目标我们最终选择了Microsoft Office Word做为本软件的终端输出。本软件是在对现有控件的改进和VBA编程的研究的基础上开发的。本软件实现了以下主要功能:1.手动生成试卷;2.自动生成试卷;3.抽取现有试卷;4.用户管理;5.数据库管理。大量的测试表明本软件在Windows 98me2000XP平台配合O

2、ffice XP2003 的环境下程序运行稳定且各项功能运行得都很正确,基本达到了预期的要求!结论:经过老师的实际试用本软件在界面上和功能上都有独到之处!相信完全可以胜任出一份好的试卷任务。关键词:题库系统,试卷生成,数据库,VBAAbstractThe general situation teacher thinks out a paper,reach huge exam pool each finds out the question, or shoulder the question together out from several relevant books. Time-consu

3、ming and also strenuous like this, and very difficult to guarantee coverage rate and paper degree of difficulty of examination question. Helping the teacher thinks out a higt quality paper is the destination of develop this Software. In the cause of this we select the terminal is Microsoft Office Wo

4、rd. This Softwares base of develop is improve on control in existence and study the VBA programing. These functions of this software are as follows: One. Manual create paper; Two. Auto create paper; Three. Select from existential papers; Four. User manage; Five. Database manage. The result of many t

5、est is that this software is runing steady and these funtions of it is runing right in the environment which make up of Windows 98me2000XP and Office XP2003, it is basic reach the requests. In all: the result of real test by teacher is that this software are unique in interface and function. We must

6、 believe it can complete creating a high quality paper.Key Words:Exam,Problem pool,VBA,word目录前言在开发本软件之前,正是我努力提高自己的Delphi开发水平的时期。因此我选择了Delphi做为我的开发工具,然而这次开发的软件和以前不一样。最主要的区别在于这个软件要以Microsoft Office Word做为试卷的终端输出。而它们又是两个不同公司的产品。因而,刚一开始我特别担心这个技术能否得到比较圆满的解决。在开发的过程中我不断的对VBA技术进行研究,并且将它应用于这次的软件开发中。因而比较好的解决了

7、Microsoft Office Word的接口编程问题。还有一个比较棘手的问题就是Delphi提供的控件都是很基本的,而这次开发中要用到一个可以标记选中状态的树型控件,在对Delphi的TtreeView的深入研究后确认它不能胜任这个任务。因此,我开始寻找第三方控件,然而这一次我很失望因为只找到了一个2000年编写的TCheckTree控件,没办法了,最后下定决心修改那个TCheckTree控件以使它能更加稳定和实用。在深入研究Windows的消息机制和VCL框架对Windows消息机制的封装技术后我成功的修改了那个TCheckTree控件。在程序开发的后期测试中,我充分利用各个同学电脑平台

8、的多样性。把本软件在多达4种操作系统和3个不同版本的Office上进行测试。测试表明:在Windows 98me2000XP平台配合Office XP2003 下程序运行稳定且各项功能运行得都很正确!1 . 简述1.1 开发工具简介1.1.1 Delphi 7.0的特点Delphi是Borland公司出品的开发工具,在众多的开发工具中,我们为什么要选择Delphi呢?因为Delphi具有众多其它开发工具所没有的优点!具体介绍如下: 开发的高效 语言的高效 编译的高效 执行的高效 维护的高效基于以上理由,我们毫不忧郁的选择了Delphi做为我们的开发工具!1.1.2 主要的控件及其属性简介 TF

9、orm类的控件:1) BorderIcons属性:用来控制程序标题按钮的可用性。2) BorderStyle属性:用来控制程序边框的样式。3) Color属性:用来控制程序界面的颜色。4) Font属性:用来控制程序界面的字体。5) Position属性:用来控制程序运行时界面的显示位置。 TADOConnection类的控件:6) ConnectionString属性:用来控制链接字符串。7) LoginPrompt属性:用来控制链接时是否要输入密码。8) Connected属性:用来控制是否进行链接。 TADOQuery类的控件:9) Connection属性:用来指定和哪个TADOCon

10、nection控件相连。10) SQL属性:用来添加向数据库提交的SQL语句。11) Add方法:用来向SQL属性添加SQL语句。12) Open方法:用来执行SQL语言中的Select语句。13) ExecSQL方法:用来执行任何SQL语句。14) FieldByName属性:用来给数据库的字段赋值。15) FidldValues属性:用来取出数据库的字段的。16) Append方法:用来向数据库添加一条记录。17) Edit方法:用来编辑当前的记录。18) Post:用来向数据库提交所做的修改。 TADOTable类的控件:19) Connection属性:用来指定和哪个TADOConne

11、ction控件相连。20) Open方法:用来打开数据库中指定的表。21) FieldByName属性:用来给数据库的字段赋值。22) FidldValues属性:用来取出数据库的字段的。23) Append方法:用来向数据库添加一条记录。24) Edit方法:用来编辑当前的记录。25) Post:用来向数据库提交所做的修改。 TDataSource类的控件:26) DataSet:用来指定和哪个数据集相连。 TDBGrid类的控件:27) DataSource:用来指定和哪个TDataSource控件相连。 TPageControl类的控件:28) ActivePage属性:用来指定当前活动

12、的Page页。 TCheckTree类的控件:29) ReadOnly属性:用来控制TCheckTree内的Item是否可编辑。30) Item属性:用来控制TCheckTree包含的所有树形结点。31) Images属性:用来指点TCheckTree中结点的图标。32) OnMouseUp事件:用来添加鼠标放开事件所执行的程序代码。33) OnStateChange事件:用来添加结点状态改变时的程序代码。 TFlatButton类的控件:34) Caption属性:用来指定TFlatButton的标题。OnClick事件:用来添加按钮的单击事件所执行的程序代码。1.1.3 数据库连接方式选择

13、Delphi连接数据库的主要方式有两种:一是:BDE ,二是ADO 。现在我们来大致比较一下这两种技术的优缺点:BDE(Borland Database Engine)是Delphi颇具特色的数据库连接管理技术。凭借窗体和报表,BDE可以访问诸如Paradox,dBASE,本地InterBase服务器的数据库,也可访问远程数据库服务器上的数据库,如Oracle,SyBase,Informix等CS数据库中的数据库,也可访问经ODBC可访问的数据库管理系统中的数据库。ADO(ActiveX Data Objects)是微软提供的一项技术。通过ADO,可以方便的访问各种类型的数据库,特别是OLED

14、B数据库。ADO已成为访问数据库的新的标准接口。从Delphi 6.0开始Delphi添加了对ADO的支持,以便让用户能迅速实现对终端用户用来做商业决策的数据库的一致性访问,结合Delphi本身的开发式数据组件结构,程序员可以很快地建立应用程序,用来把自己的商业数据库通过Internet发送给客户,最终用户以及整个销售环节。通过ADO,Delphi 7.0也能让用户快速访问关系或非关系数据库以及E-Mail和商务文件系统。这两者提供了几乎相同的功能,在进行产品开发时,势必要做一个精心的比较。虽然ADO技术提出的时间不长,并被定位为工业标准的,而且其在性能上由于当前没有良好的数据库引擎支持,其性

15、能还不够完美,但是,我们应该要注意到Borland公司已经宣布停止发展BDE了,其性能被ADO超越也是迟早的事,因此,在开发长期应用的产品时,推荐采用ADO技术。这样还有另一个好处是,在进行产品分发时,可以避开大量BDE的链接库DLL的分发。基于以上原因我们选择了ADO做为我们的数据库访问组件。1.2 程序运行环境操作系统:Windows 2000Windows XP办公软件:Office XPOffice 20032 . 需求分析2.1 负责的功能模块 设计试题生成功能,试题能分布整个教学内容 设计试题的难易程度分析功能 具有试题的答案生成功能 数据库设计及维护 程序的其它选项设置2.2 软

16、件功能分析根据我负责的功能模块,主要是在试卷的生成上。1要显示书本章节信息以供用户使用。而在数据库里章节的存放是没有规则也即它们的顺序不一定按照真实书本的章节顺序来存储的。但是在显示章节信息的时候必须按照书本的章节顺序来显示。所以特别设置如下的数据类型:type ZJ=record ZJID:double; ZJName:string; end;在这里ZJID是设置成double的类型与相对应的是数据库里表ZhangJie里的ZJ字段此字段的类型为文本弄的。故在添加此数据库结构的时候要把文本型转化为double的类型。而ZJName对应的是数据库里表ZhangJie里的ZJName它们为同一种

17、数据类型。再由于数据库里章节的数量是不定的,故此种数据类型的变量必须是一种长度可变的类型才行,所以我们选择了Delphi里的动态数组类型。变量定义如下 :Var TempZJ:ZJ;HaveZJ:array of ZJ;接下来的问题就是把这个变量记录的数据按一定顺序显示到TCheckTree的控件里了。由于章节的数量还是比较多的,所以我选择了“改进的选择排序”,具体的排序算法代码实现如下: for i:=0 to High(HaveZJ) do /对章节号进行排序 begin k:=i; for j:=i+1 to MaxNum do if HaveZJk.ZJIDHaveZJj.ZJID t

18、hen k:=j; if ik then begin TempZJ.ZJID:=HaveZJi.ZJID; TempZJ.ZJName:=HaveZJi.ZJName; HaveZJi.ZJID:=HaveZJk.ZJID; HaveZJi.ZJName:=HaveZJk.ZJName; HaveZJk.ZJID:=TempZJ.ZJID; HaveZJk.ZJName:=TempZJ.ZJName; end; end; 2手动生成试卷时要不断的将用户选择的题目临时存储起来,由于记录一道题所包含的信息不是很多,再因为这些信息一会儿还要在“保存答案”里使用,所以我设置了4个TStringList

19、的全局变量,定义如下: var STTypeID,STBH,STND:TStringList;每选一道题保存时的算法代码如下:首先保证要添加入的试题与现有的试题不能重复。LX:=ST_DBG.Fields1.AsInteger;BH:=ST_DBG.Fields0.AsInteger;for i:=0 to STTypeID.Count-1 do beginif (StrToInt(STTypeID.Stringsi)=LX)and(StrToInt(STBH.Stringsi)=BH) then begin MessageBox(handle,要加入的试题已经存在了!,加入错误,MB_OK

20、or MB_ICONERROR); exit; end; end;如果不重复的话则把试题添加进来!STTypeID.Add(IntToStr(LX); /记下试题类型STBH.Add(IntToStr(BH); /记下试题编号STND.Add(ST_DBG.Fields4.AsString); /记下试题难度 3在自动生成试卷里最主要的一点就是如何生成一个覆盖知道点广且试题不重复的试卷。其中的关键算法在于如何生成一个不重复的随机数序列。在Delphi里随机数的产生函数是Random,然而如果用这个函数来生成一定范围内的随机数重复的机率太大了。其中变量定义如下: var XTH:array of

21、 integer; /存放随机选题号以下是产生不重复随机数的算法: num:=MaxBH-MinBH+1; if num0 then /开始初始化 begin SetLength(XTH,num); for i:=0 to num-1 do XTHi:=MinBH+i; /给动态数组设初值 Randomize; /初始化随机数生成器 for i:=0 to num-1 do begin j:=random(num); temp:=XTHi; XTHi:=XTHj; XTHj:=temp; end; end;3 . 设计阶段3.1 概要设计3.1.1 系统数据库设计根据任务书的规定,现设计如下的

22、数据库表格:表:用户表(YH)字段中文名字段英文名字段类型字段长度主键姓名UserName文本20是密码Password文本18组GroupID数字长整型权限QXID数字长整型 表:题型(Type)字段中文名字段英文名字段类型字段长度主键编号TypeID自动编号是名称TypeName文本20分值FZ数字长整型 表:难易度(NYD)字段中文名字段英文名字段类型字段长度主键编号BH自动编号是难易度NYD文本 表:用户组(UserGroup)字段中文名字段英文名字段类型字段长度主键编号GroupID自动编号是组名GroupName文本20表:选择题(XuanZeTi)字段中文名字段英文名字段类型字段

23、长度主键题号TH自动编号是题型TypeID数字长整型题目TM备注选项AA文本255选项BB文本255选项CC文本255选项DD文本255正确答案DA文本难易度NY数字长整型出自章节CZ文本50表:填空题(TianKong)字段中文名字段英文名字段类型字段长度主键题号BH自动编号是题型TypeID数字长整型题目TM备注空1K1文本100空2K2文本100空3K3文本100空4K4文本100空5K5文本100应填数YTS数字长整型难易度NY数字长整型出自章节CZ文本50表:简答题(JianDaTi)字段中文名字段英文名字段类型字段长度主键题号BH自动编号是题型TypeID数字长整型题目TM备注答案

24、DA备注难易度NY数字长整型出自章节CZ文本50表8:原理论述题(YuanLiLunShu)字段中文名字段英文名字段类型字段长度主键题号BH自动编号是题型TypeID数字长整型题目TM备注答案DA备注难易度NY数字长整型出自章节CZ文本50表9:系统设计题(XiTongSheJi)字段中文名字段英文名字段类型字段长度主键题号BH自动编号是题型TypeID数字长整型题目TM备注表格BG文本100答案DA备注难易度NY数字长整型出自章节CZ文本50答案表格DABG文本50题目表格TMBG文本50表10:系统操作题(XiTongCZ)字段中文名字段英文名字段类型字段长度主键题号BH自动编号是题型Ty

25、peID数字长整型题目TM备注难易度NY数字长整型出自章节CZ文本50题目表格TMBG文本50问1答案W1DA文本255问1答案表格W1DABG文本50问2答案W2DA文本255问2答案表格W2DABG文本50问3答案W3DA文本255问3答案表格W3DABG文本50问4答案W4DA文本255问4答案表格W4DABG文本50问5答案W5DA文本255问5答案表格W5DABG文本50问题数WTS数字长整型3.2 详细设计3.2.1 程序流程图1抽取现有试卷的流程图:2自动生成试卷的流程图:3下图是手动生成试卷的流程图:3.2.2 窗体功能简介下图软件的登陆界面在这里输入用户名及密码就可以进行入软

26、件的主界面了!下图是软件的主界面:在以上的软件主界面的左边是各个功能模块的调用接口!如:抽取现有试卷:点击后进入抽取现有试卷的功能界面。自动生成试卷:点击后进入自动生成试卷的功能界面。手动生成试卷:点击后进入手动生成试卷。题库录入:在这里可以往数据库里添加试题。题库维护:在这里可以对数据库里已有试题进行维护。选项设置:在这里可以对软件的其它选项进行设置。软件的右上角有“帮助”和“关于”按钮!在这里可以得到软件的使用帮助,和有关此软件的一些开发信息!下图是自动生成试卷的界面:上图中标为“第一部分”的树形控件是用来设置要生成的试卷的试题的抽取范围。上图中标为“第二部分”的是用来设置各种题型的量及其

27、分数。上图中标为“第三部分”的是功能按钮,其中“生成试卷”用来根据“第二部分”的设置自动生成一份试卷。“预览试卷”是用来预览刚生成的试卷。“试卷答案”是用来查看刚生成的试卷的答案。“保存试卷”是用来保存刚生成的试卷的信息。下图是手动生成试卷的界面图:上图中标为“第一部分”的树形控件是用来设置要生成的试卷的试题的抽取范围。上图中标为“第二部分”的是用来设置各种题型的量及其分数。上图中标为“第三部分”的是用来设置试卷的部分。上图中标为“第五部分”的是用来选择要加入试卷的试题。上图中标为“第四部分”的是功能按钮,其中“加入试卷”用来把在“第五部分”的选择试题加入到要生成的试卷中。“保存试卷”是用来保

28、存刚生成的试卷的信息。下图是用户管理的界面:上图中标为“第一部分”显示当前系统已有的用户。上图中标为“第二部分”选择要进行的操作。上图中标为“第三部分”设置相应的信息。上图中标为“第四部分”。可以删除用户或是提交对用户信息的修改。下图是数据库功能模块的界面:上图中标为“第一部分”可以改变数据库的存放路径。上图中标为“第二部分”选择要进行的操作。上图中标为“第三部分”选择还原的时间点或是执行备份操作。4 . 软件实现4.1 OOP简介每一个软件开发人员都会经常听到,看到“面向对象”这个词,程序员也时常把它挂在嘴上。那么什么还是真正的“面向对象”?什么是面向对象的编程?是不是写几个类就算面向对象了?为什么要面向对象?“面向对象是一种思维方式,一种方法论!”“结构化编程”(SP)是一种编程方法,是从计算机的视角来抽象问题的方法。而“面向对象编程”(OOP)也是一种编程方法,只不过它是从

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1