VF数据库第11章程序设计基础.ppt
《VF数据库第11章程序设计基础.ppt》由会员分享,可在线阅读,更多相关《VF数据库第11章程序设计基础.ppt(66页珍藏版)》请在三一办公上搜索。
1、第十一章 结构化程序设计,11.1 VFP的工作方式,Vfp系统提供了三种工作方式,即命令方式、菜单方式和程序文件方式。1、命令方式特点:输入一条操作命令,系统完成一个数据库的操作。2、菜单方式:通过菜单选择相应的操作。3、程序方式:所谓程序执行方式,就是将实现某一功能的VFP命令序列,在编辑器中编成特定的程序文件,存放在磁盘中,其文件扩展名为Prg。当我们需要实现这一功能时,就执行该程序。特点:通过程序文件中的命令,完成对数据库的操作和系统环境的设置。,4、程序文件的建立、执行和编译 1命令方式 Modify Command 2菜单方式 单击系统菜单“文件”、“新建”,弹出“新 建”窗口。在
2、“新建”窗口中,选择“程序”、“新建文 件”,进入“程序文件编辑”窗口。在“程序文件编辑”窗口中,逐条输入命令行。结束后,单击系统菜单“文件”、“保存”,在 窗口的“保存文档为:”对话框中,输入程序文 件名,默认的文件类型为*.Prg,单击“保存”按钮,建立程序文件的操作结束。,5、程序文件的执行 程序文件保存在磁盘上,在需要运行时可从磁盘调入内存执行。注意:程序运行后,会自动产生一个文件类型为.Fxp的同名的编译程序。1命令方式 Do程序文件名2菜单方式 单击系统菜单的“程序”、“运行”,在弹出的“运行”窗口中,选择路径、双击需要运行的程序名。,11.2 程序的基本结构,在VFP中,常见的程
3、序基本控制结构有:1、顺序结构:顺序结构是最基本、最普通的结构形式。运行时,也是按照命令书写时的先后次序来执行,在程序执行的过程中不改变命令执行次序的一种结构。2、分支结构:编写顺序结构程序虽然简单,但在实际应用中,经常需要对事物做出一定的判断,并依据判断的结果采取不同的处理行为。例如:求圆的面积,对半径要做处判断,是否大于0,如果是才能参加运算,否则不能运算,输出参数错误信息。分支结构有三种基本格式:单分支选择、二分支选择(选择函数)和多分支选择。,3、循环结构:重复循环操作,特别是若根据条件来决定是否重复执行某段程序,那么顺序结构和分支结构显然是无能为力。Vfp提供的循环结构程序设计就可以
4、解决这一问题。事实上70%以上的实际问题的处理过程都需要使用循环结构。循环结构是当条件满足时,反复执行循环体内的命令系列,一直到条件为假时,才退出循环,执行循环体外的系列命令。4、过程结构:在程序的许多位置反复执行某些程序段,且常将这些程序段和嵌入它的程序分开,形成独立的程序序列,待使用时再调入程序中,以实现不同位置上的重复操作。,1输入语句 输入语句提供了在程序运行的过程中暂停程序的执行,等待用户从键盘上输入数据,当用户以回车键结束输入时,系统将表达式的值存入指定的内存变量,程序继续运行。输入语句有非格式化输入命令和格式化输入命令两种。(1)非格式化输入命令 非格式化输入命令共有三条:Inp
5、ut、Accept和Wait。Input To内存变量Accept To内存变量Wait To内存变量,11.3 顺序结构语句,参数说明:Input命令能接受除备注型、通用型以外的数据类型,但数据为字符型、日期型或逻辑型时应使用相应的定界符。Accept命令只接受字符型数据。输入字符串时,不需要用定界符。Wait To内存变量命令只接受单个字符。如果执行不带任何参数的Wait命令会弹出“按任意键继续”的提示。,例:在学生档案表中,按姓名直接定位查询学生记录。Use 学生档案表 Accept”请输入查询学生的姓名:”To A1 Locate For 姓名=A1 Display例:在学生档案表中,
6、按年龄顺序定位查询学生记录。Use 学生档案表 Input“请输入查询学生的年龄:”To A2 Locate For 年龄=A2 Display Continue Display,(2)屏幕格式输入语句 在指定行、列的位置,从键盘上为变量赋值。这个变量可以是内存变量,也可以是字段变量。如果是内存变量,必须事先定义好。如果是字段变量,必须事先打开相应的数据表。Say Get,参数说明:Say:是作为被编辑的变量前面出现的提示,一般都是用字符串表示。Get:变量可以是内存变量,也可以是字段变量。如果是内存变量必须在使用前先定义。如果是字段变量,则要先打开相应的数据表。数据类型可以是数值型、字符型、
7、日期型、逻辑型或备注 型。Get命令,必须用Read语句来激活才能完 成对数据的编辑。多个Get命令,可以用一个 READ语句来激活。,例:用屏幕格式输入语句输入数值,计算公式C=2A+3B的值。A=0 B=0 10,20 Say“请输入数值:”Get A 11,20 Say“请输入数值:”Get B Read?”C=2A+2B=”+Str(2*A+2*B),例:请编辑一个程序,能根据学号和课程名称来修改成绩。CLEAR Xh=Space(7)Kcdm=Space(3)Use 学生成绩表 Excl 10,20 Say 请输入要修改成绩的学号 Get xh 12,20 Say 请输入要修改成绩的
8、课程代码 Get kcdm Read Locate For 学号=Xh.And.课程代码=Kcdm 12,20 Say 请输入修改成绩 Get 成绩 Read,2输出语句(1)非格式化输出命令 格式:?表达式表 格式2:?表达式表 格式3:?表达式表 计算表达式的值并输出。参数说明:“?”表示在当前行的下一行的首位输出,”?”表示在当前行光标处输出,”?”表示向打印机输出。如果是字符、日期、逻辑常量应使用定界符。如果是一个表达式,则各部分的数据类型必须一致。如果是,各表达式之间用逗号“,”分隔。,例:显示当前的日期和时间与表达式的值。?今天的日期是:,DATE(),时间是:,TIME()&如果
9、用“+”连接该如何表达 A=10 B=20?A*10-B=,Str(A*10-B),Space(2)?“A*20-B=”+Str(A*20-B,4)例:显示字符型表达式的值。?祝贺+北京申奥+成功&字符串的连接,(2)屏幕格式输出命令 SAY Picture P223 在指定行、列位置上输出表达式的值。参数说明:Say:表达式可以是常量(字符、日期、逻辑常量需要使用相应的定界符)、内存变量、字段变量以及由它们组成的表达式。表达式只能是一个,而且,表达式的各部分的数据类型必须一致。,例:显示字符串常数。3,5 Say 这是一个显示字符串常数的例子“例:显示学生档案表的第四条记录的字段内容。Use
10、 学生档案表 Goto 4 6,6 Say 学号::+学号 7,6 Say 姓名::+姓名 9,6 Say 年龄:+Str(年龄,2)&数据类型必须一致 10,6 Say 出生日期:+Dtoc(出生日期),二、清屏与注释语句1清屏语句 Clear 清除屏幕上所有显示的内容。2注释语句 Note*&Note和“*”注释语句在程序中单独作为一行,作为程序的注释。&注释语句一般写在命令的后面,作为该命令的注释。,三、终止程序执行语句1Return 或Cancel 终止程序的执行,关闭打开的命令文件,返回到 Foxpro系统的命令窗口。2Quit 终止程序的执行,关闭打开的命令文件,返回到window
11、s操作系统状态。3Retry 终止程序的执行,返回到调用行本身,可以实现程序的重复调用。4.文本输出命令TEXT 格式:TEXT“提示信息”ENDTEXT,例:编写一个求梯形面积的程序。Input 请输入梯形的上底:To M Input 请输入梯形的下底:To N Input 请输入梯形的高:To H?梯形面积=,Str(M+N)*H/2,10,2)Return例:编写一个在“学生档案表”中查询年龄大于18岁的98级浙江籍的学生记录的程序(注意:假设数据表字段中只有出生日期而无年龄字段、学号前二位为年级)。ClearUse 学生档案表List For Year(Date()-Year(出生日期
12、)23.And.Subs(学号,1,2)=98.And.籍贯=浙江UseReturn,编写顺序结构程序虽然简单,但在实际应用中,经常需要对事物做出一定的判断,并依据判断的结果采取不同的处理行为。例如:求三角形的面积,对三条边要做处判断,是否构成三角形,如果是才能参加运算,否则不能运算,输出参数错误信息。分支结构有三种基本格式:单分支选择、二分支选择(选择函数)和多分支选择。,11.4 分支结构语句,1单分支选择 If Endif Return参数说明:单分支选择结构是当条件表达式为真时,执行,然后,再执行EndIf后面的。如果 条件表达式为假,则直接执行EndIf后面的。IF和EndIf必须成
13、对出现,缺一不可。可以是表达式或表达式的逻辑组合,表 达式的值必须是逻辑值。,例:从键盘上输入一个数,若是偶数,则输出。Input“请输入数据:”To X If Int(X/2)=X/2?X,”为偶数”Endif Return例:在学生档案表中,查询王启明的籍贯是否为“江西”。如果是,则输出本记录的姓名、学号、班级和年龄。Clear Use 专业特长 Locate For 编号=“GZ05002 If 职称=“教授 replalce 职称 with“副教授”Endif browse last,在上程序并不完善,即当条件不满足时,程序中不能做出进一步的处理。这就说明单分支的功能是有限的,不能完善
14、地解决分支处理问题。而二分支选择结构就可以处理好这个问题。2双向分支选择结构 If条件表达式 A系列命令 Else B系列命令 Endif D系列命令Return,二分支选择结构,首先判断条件表达式的逻辑值,若条件为“真”时,执行A系列命令。然后,再执行ENDIF后面的D系列命令。若条件为“假”时,执行Else后面的B系列命令。然后,再执行ENDIF后面的D系列命令。,例:当行李重量W20KG时,其超过部分则加倍计算收费。Input“请输入行李重量:”To W If W=20 Y=W*0.15 Else Y=W*0.15+(W-20)*0.3 Endif?“运费y=”,Y Return,例:用
15、二分支选择结构完善例5-19程序。Input 输入三角形的a边:To AInput 输入三角形的b边:To BInput 输入三角形的c边:To C If A+BC.And.B+CA.And.C+AB P=(A+B+C)/2 S=Sqrt(P*(P-A)*(P-B)*(P-C)?三角形的面积为:,S Else?输入的边长有错,无法构成三角形!Endif Return,补充:3IIF()选择函数 IIF()函数是双分支选择语句IfElseEndif的简单形式。在某些情况下,可以用IIF()函数代替IfElseEndif语句,从而简化条件描述,提高程序的执行速度。IIF(,)参数说明:若的值为真,
16、则函数返回的值。否则,返回的值。返回值的类型可以是字符型、日期型、数值型和逻辑型。与的数据类型必须是一致。,例:在工资管理数据表中,如果基本工资小于700时,将基本工资加150。否则,加120。Use 工资管理数据表 Repl All 基本工资 With 基本工资+Iif(基本工资 700,150,120),4多向分支选择结构 虽然可用IF语句嵌套的方式解决多分支选择问题。但是,如果选择的分支很多,则编写的程序可读性差且易出错。这时,一般使用DO CASE-ENDCASE多重分支选择结构来解决。,参数说明:执行多重分支选择结构时,会依次判断至的逻辑值,只要一遇到条件表达式为真时,就执行该条件表
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- VF 数据库 11 章程 设计 基础

链接地址:https://www.31ppt.com/p-6524418.html