VFP程序设计简明教程-鲁俊生第2章-常量、变量、表达式及函数ppt课件.ppt

上传人:飞****2 文档编号:92523386 上传时间:2023-06-06 格式:PPT 页数:83 大小:509KB
返回 下载 相关 举报
VFP程序设计简明教程-鲁俊生第2章-常量、变量、表达式及函数ppt课件.ppt_第1页
第1页 / 共83页
VFP程序设计简明教程-鲁俊生第2章-常量、变量、表达式及函数ppt课件.ppt_第2页
第2页 / 共83页
点击查看更多>>
资源描述

《VFP程序设计简明教程-鲁俊生第2章-常量、变量、表达式及函数ppt课件.ppt》由会员分享,可在线阅读,更多相关《VFP程序设计简明教程-鲁俊生第2章-常量、变量、表达式及函数ppt课件.ppt(83页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.1 数据类数据类 型型 2.2 常量与变量常量与变量2.3 表达式表达式2.4 常用函数常用函数第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.1 数据类型数据类型人们用数据来描述实体的对象及其属性。数据类型是数据的基本属性,是一个重要的概念。在VisualFoxPro中,只有相同类型的数据之间才能直接运算,否则就会发生数据类型不匹配的错误。VisualFoxPro是一种关系数据库管理软件。在关系数据库中把描述每一实体集合的数据表示成一张二维表。例如

2、,表示学生档案的一张二维表如下所示:第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 其中,第一列“Record#”是记录号,在这个学生档案中共有6名学生的记录数据,即6个记录。二维表中的第一行描述了每个记录的结构,由第一行的描述可以看出每个记录由5个部分组成,记录的这些组成部分称为字段。表中学生记录5个字段的字段名分别为学号、姓名、性别、出生年月日、籍贯。由于在记录的字段中存放的是数据,因此,字段和数据一样也具有数据类型属性,称为字段类型。在VisualFoxPro中共定义了13种字段类型和7种数据类型。第第2章章 常

3、量、变量、表达式及函数常量、变量、表达式及函数 13种字段类型分别是:字符型、数值型、浮动型、双精度型、整型、货币型、日期型、日期时间型、逻辑型、备注型、通用型、二进制字符型和二进制备注型;7种数据类型分别是:字符型、数值型、货币型、日期型、日期时间型、逻辑型和通用型。字段是表文件所特有的,而数据则既可作为表文件中字段的内容,也可以作为内存变量的内容,还可以作为常量使用。1.字符型字段和字符型数据字符型字段和字符型数据字符型字段用于存放字符型数据。字符型数据是指一切可印刷的字符,其中包括英文字母、阿拉伯数字、各种符号、汉字及空格。一个字符型字段可以存储1254个字符。上述学生档案中的“学号”和

4、“姓名”字段就是字符型字段,其中存储的学号和姓名数据是字符型数据。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.数数值值型型、浮浮动动型型、双双精精度度型型和和整整型型字字段段与与数数值值型数据型数据数值型字段中存储的是数值数据。数值数据的每一位占一个字节;浮动型字段中存放浮点数值数据。这两个字段中可以存储最长达20位的数据。整型字段中存放整数,可以存放的最大和最小整数分别为+2147483647和-2147483647,用该类型字段存放较大整数时可节省存储容量,因为它只占用4个字节。双精度字段用于存放双精度数,可得到15位精度常用于科学计算,但双精度字段要占用8个字节的存

5、储容量。上述这些字段中存放数据都是数值型数据。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 3.货币型字段和货币型数据货币型字段和货币型数据货币型字段用于存放货币型数据,其中可存放的最大数为+922337203685477.8087,只占用8个字节。4.日期型字段和日期型数据日期型字段和日期型数据日期型字段用于存放日期型数据,常用日期格式为“年.月.日”和“年/月/日”。学生档案中的“出生年月日”字段就是日期型字段,其中的数据就是日期型数据。日期型字段有固定宽度,占用8个字节,其中年、月、日各占两个字节。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 5.日期时间

6、型字段和日期时间型数据日期时间型字段和日期时间型数据日期时间型字段用于存放日期时间数据,它占用8个字节。其格式为:年.月.日.时:分:秒AM或PM。6.逻辑型字段和逻辑型数据逻辑型字段和逻辑型数据逻辑型字段用于存放逻辑型数据。逻辑数据只有两个值,即“真”和“假”,常用于逻辑判断。逻辑型字段的宽度固定,为1个字节。在输入逻辑型数据时可用英文字母T、t、Y、y中任何一个字符代表“真”,而用F、f、N、n中的任何一个字符代表“假”。学生档案中的“性别”字段就是逻辑型字段,可用“真”表示男性,而用“假”表示女性。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 7.备注型字段备注型字段备注

7、型字段可存放字符文本、源程序代码等多种信息,因而得到广泛的应用。通常使用备注型字段来记录那些可有可无、可长可短的信息,如学生档案中的奖惩记录(有些人可能获奖或受到处分,而多数人可能没有此项数据)。此外,备注型字段也常用于存放运行程序时的帮助信息。备注型字段中的信息实际上并不是存放在表文件中,而是存放在与表文件同名,但扩展名为“.FPT”的备注文件中。创建表文件时,如果定义了备注型字段,相应的备注文件就会自动生成;备注文件生成后会随表文件打开而自动打开。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 8.通用型字段和通用型数据通用型字段和通用型数据通用型字段可存放图片、电子表格、声

8、音、设计分析图及字符等数据。通用型字段使得VisualFoxPro成为全方位数据库。和备注字段一样,通用字段中的数据也存入与表文件同名而扩展名为.FPT的文件中。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.2 常量与变量常量与变量2.2.1 常量常量FoxPro定义了4种类型常量:数值常量、字符常量、逻辑型常量和日期型常量。1.数值型常量数值型常量数值型常量可以是整数或实数,例如,89,34.56等在程序中都是数值型常量。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.字符型常量字符型常量字符型常量是用定界符括起来的由字符、空格和数字所组成的字串。定界符

9、可以是单引号、双引号或方括号。当某一种定界符本身就是字符常量的组成部分时,就应选用另一种定界符。例如:abcd、高级工程师、胡天云、pict999.9等在程序中都是正确的字符型常量,而MSD、abcdefghi都不是正确的字符常量。3.逻辑型常量逻辑型常量逻辑型常量只有两个值:“真”与“假”。用.T.、.t.、.Y.、.y.表示“真”,用.F.、.f.、.N.、.n.表示“假”,注意两边的小圆点不能丢掉但可以用空格代替。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 4.日期型常量日期型常量日 期 型 常 量 必 须 用 花 括 号 括 起 来,例 如,2000.03.15、20

10、00/03/15都是日期型常量的正确写法。2.2.2 变量变量FoxPro定义了3种类型变量:字段变量、用户内存变量和系统内存变量。用户内存变量又简称为内存变量。前两种变量的名称可用110个字母、下划线和数字表示,但必须以字母打头,而后一种变量名称由系统规定。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 1.字段变量字段变量字段变量是表文件结构中的数据项。FoxPro定义了13种类型字段变量,这在2.1节已经全面介绍过,这里再补充一点,就是字段变量是一种“多值”变量,如学生档案这个表文件有多条记录,则表的各个字段就有多个值。移动记录指针位置到所需记录,就可以找出字段变量的当前值

11、。2.内存变量内存变量内存变量是在数据库结构之外独立存在于内存中的变量,一般随程序运行结束或退出FoxPro而释放。内存变量常用于存储程序运行的中间结果或用于存储控制程序执行的各种参数。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 FoxPro定义了5种类型内存变量,即字符型、数值型、逻辑型、日期型和屏幕型内存变量。在FoxPro最多可以定义65000个内存变量。另外,FoxPro还提供一维和二维内存变量数组。3.系统内存变量系统内存变量系统内存变量是FoxPro自动生成和维护的变量,用于控制FoxPro的输出和显示信息的格式。为与一般内存变量相区别,在系统内存变量名前加一下划

12、线“_”。例如,系统变量_PEJECT用于设置打印输出时的走纸方式,该系统变量的缺省值是“BEFORE”,即打印前走纸换页,用户可将其设置为“NON”,即打印前后都不换页走纸。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.2.3 内存变量赋值命令内存变量赋值命令FoxPro中有多种命令可以定义内存变量和给内存变量赋值,常用的赋值命令格式如下:STORETO|和|=这两条命令都用于定义内存变量并给变量赋值,不同之处是前一个命令可定义多个内存变量并给这些变量赋以同一数据,后一个命令只能定义单个内存变量或变量数组。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2

13、-1定义常用类型的内存变量并将其赋值。在FoxPro命令窗口中键入如下命令:store12.34toastore吕小青tobstore.t.tocstore2000.03.15toddimensione(2,3)e(1)=12.34第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 e(2)=吕小青e(3)=.t.e(4)=2000.03.15listmemorylike?屏幕显示的执行结果如下:AN12.34(12.34000000)BC吕小青CL.T.DD2000.03.15第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 EA(1,1)N12.34(12.34000

14、000)(1,2)C吕小青(1,3)L.T.(2,1)D2000.03.15(2,2)L.F.(2,3)L.F.第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 在例2-1中有关FoxPro命令的功能简介如下:store12.34toa定义内存变量a,数值型,其值为12.34。store吕小青tob定义内存变量b,字符型,其值为“吕小青”。store.t.toc定义内存变量c,逻辑型,其值为“真”。store2000.03.15tod定义内存变量d,日期型,其值为2000年3月15日。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 dimensione(2,3)定义二

15、维变量数组e,该数级有二行三列,共6个元素:e(1,1)、e(1,2)、e(1,3)、e(2,1)、e(2,2)、e(2,3)。这些元素被定义作逻辑型并赋以初值“假”。二维数组元素还可以用单下标相应表示作e(1)、e(2)、e(3)、e(4)、e(5)、e(6)。e(1)=12.34数组元素e(1),即e(1,1),赋值12.34,其类型已转换为数值型。e(2)=吕小青数组元素e(2),即e(1,2),赋值吕小青,其类型已转换为字符型。e(3)=.t.数组元素e(3),即e(1,3),赋“真”值,其类型不变仍为逻辑型。e(4)=2000.03.15数组元素e(4),即e(2,1),赋一日期值,

16、其类型已转换为日期型。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 Listmemorylike?内存变量显示命令。其中子句“like?”中 的 问 号 为 通 配 符,代表任一字符。此命令意义为只显示以一个字符为名的所有内存变量的属性。若不加子句“like?”,则Listmemory命令还要显示系统内存变量的有关属性。在FoxPro系统中规定如果内存变量与打开的当前表文件的字段同名时,字段名优先。此时如若要使用同名内存变量,则必须加写“M-”或“M.”进行限定,即M-内存变量名或M.内存变量。其中,限定由M、减号和大于号或由M和圆点组成。第第2章章 常量、变量、表达式及函数常

17、量、变量、表达式及函数 2.3 表达式表达式2.3.1运算符1.算术运算符算术运算符算术运算符包括:(1)()分组优先运算符;(2)*、乘幂运算符;(3)*、/乘除运算符;(4)%求余运算符;(5)+、-加减或单目运算符。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 算术运算符主要用于数值数据间的算术运算。数值数据运算的结果也是数值型数据。如果在一个表达式中同时出现多个运算符时,运算的顺序由运算符的优先级确定,优先级高的先运算,优先级低的后运算。运算符的优先级依次为括号、单目、乘幂、乘除、求余、加减,其中括号优先级最高,加减运算符优先级最低。所谓单目运算符,即只在运算符后面有运

18、算数据的运算符。例如,用户在命令窗口中键入两条显示运算结果的命令:?-2*2+5?-23+5显示在屏幕上的结果值分别为:9.0和-3.0。“?”命令的功能是命令计算机计算和显示表达式的值。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.关系运算符关系运算符关系运算符包括:(1)大于;(3)=等于;(4)=相等比较;(5)=大于等于;(7)、#、!=不等于;(8)$包含运算。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 关系运算符用于比较运算,即比较同类型表达式的值,如果其值使关系成立,则比较运算的结果取逻辑值“真”,否则取逻辑值“假”。各关系运算符的优先级相同

19、。例2-2将变量赋值并进行比较运算。命令及执行结果说明a=12.34定义数值型变量b=23.45定义数值型变量?ab 显示数值比较结果第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数.F.关系不成立取“假”值x=a 定义字符型变量y=b 定义字符型变量?xy 比较a和b字符的ASCII码.F.a的ASCII码小于b,关系不成立,取逻辑值“假”?bc$abcd比较$左边字串是否是右边字串的子串.T.是其子串,取逻辑值“真”?ac$abcd比较$左边字串是否是其右边字串的子串第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数.F.不是其子串,取逻辑值“假”?abcd=abc比

20、较等号右边字串是否是其左边字串的子串.T.是其子串,取逻辑值“真”?abc=abcd比较等号右边字串是否是其左边字串的子串.F.不是其子串,取逻辑值“假”?abcd=abc 字串等长并完全相同比较.F.不等长取逻辑值“假”第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 3.逻辑运算符逻辑运算符逻辑运算符常用作表达式之间的逻辑运算,参加运算的表达式应有逻辑值,其运算结果也是逻辑量。逻辑运算符有如下3种:(1).NOT.、!逻辑非;(2).AND.逻辑与;(3).OR.逻辑或。逻辑运算符的意义是:A.AND.B只当A和B都为“真”时,逻辑运算的结果才取“真”值,否则取“假”值。第第2

21、章章 常量、变量、表达式及函数常量、变量、表达式及函数 A.OR.B当A和B至少有一个取“真”值时,逻辑运算结果取“真”值。.NOT.A当A取“真”值时,结果取“假”值,反之结果取“真”值。3种逻辑运算的真假值如表2.1所示。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 表2.1逻辑运算真值表第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 逻辑运算符的优先级由高到低的次序为:逻辑非、逻辑与、逻辑或。例如:xb=.f.a=0b=5?a=10.and.(基本工资+浮动工资)=620.T.NOT.eof()都是正确写法的逻辑表达式。其中,eof()为文件记录指针测试函数

22、,当指针指向文件尾时返回“真”值,否则返回“假”值。所以当指针停在非文件尾时表达式.not.eof()取“真”值,常作为控制循环结束的条件。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 有一点需要说明的是在逻辑表达式定义中所提到的关系式,在有些书中称为关系表达式。关系表达式由数值型、字符型或日期型的常量、变量、函数及其表达式,通过关系运算符连接而成。其运算结果取逻辑值,即当关系成立时取“真”值,否则取“假”值。如:姓名=刘喜旺工资=630都是正确的关系表达式。其实,关系表达式是一种没有逻辑运算符的逻辑表达式特例。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 4.

23、日期表达式日期表达式日期表达式由日期型常量、日期型变量和日期型函数通过“+”,“-”等算术运算符构成,如:2000.2.11+302000.2.11-30都 是 正 确 的 日 期 表 达 式,其 结 果 分 别 为:2000.03.13和2000.01.12。注意,下面的表达式是数值型表达式:2000.2.11-2000.2.8结果为3。其实,这并不难理解,因为表达式的值为日期间隔天数,这并不是一个日期量。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.4 常用函数常用函数2.4.1 字符及字符串处理函数字符及字符串处理函数1.取子串函数取子串函数格式:SUBSTR(表达式

24、,n,m)说明:表达式指定字符表达式或备注字段;n指定取子串的起始时位置;m指定要取子串的字符数,缺省该参数指从起始位置取串尾。取子串函数用于选取字符表达式或备注型字段中的部分字符,返回值是字符型。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-4从字符串中取的3个子串。stor01,03,07tohh?subs(hh,1,2),subs(hh,4,2),subs(hh,7)结果为:0103072.删除空格函数删除空格函数删除字符数据中多余空格的函数共有3个,其格式分别如下:TRIM(表达式)ALLTRIM(表达式)LTRIM(表达式)第第2章章 常量、变量、表达式及函数常

25、量、变量、表达式及函数 这3个函数都可用于删除字符串中的多余空格,不同的是,第一个函数的功能是删除字符串尾部的空格;第二个函数的功能是删除字符串前后空格;最后一个函数的功能则是删除字符串前面的空格。其中,表达式指定了拟删除多余空格的字符表达式。显然,函数的返回值是字符型。例2-5去掉第一个字串的尾部空格,然后与第二个字串连接。storabcdetoxStorfghtoy?trim(x)+yabcdefgh第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 3.空格函数空格函数格式:SPACE(n)说明:该函数产生指定长度字符串,返回值得类型为字符型。其中,n指定产生空格的数目。例2-

26、6定义姓名及文件名(汉语拼音)变量,其初值赋予8个空格。Storspac(8)toxm,wjm第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.4.2 数学运算函数数学运算函数FoxPro提供了20余种数学运算函数,极大地增强了数学运算功能。数学函数的返回值皆为数字型。下面介绍几种常用的数学函数。1.取整函数取整函数格式:INT(表达式)说明:函数取指定数值表达式计算结果的整数部分。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-7取整并显示其结果。?int(-12.34)-122.四舍五入函数四舍五入函数格式:ROUND(表达式,n)说明:依据给出的四舍五

27、入小数位数,对数值表达式的计算结果做四舍五入处理。其中,n指定了四舍五入的小数位数。例2-8对下面给出的数做四舍五入处理并显示其结果。?round(3.14159,2),round(1024.9962,0),round(1024.9962,-3)3.1410251000第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 3.金融函数金融函数金融函数用于计算到期的本息和投资现值及每次应偿还的贷款数。1)计算每次偿还贷款数函数格式:PAYMENT(表达式,n,m)说明:表达式指定贷款本金;n指定年利率;m指定贷款总期数。该函数用于计算固定利率贷款每期需交纳的金额数。第第2章章 常量、变量

28、、表达式及函数常量、变量、表达式及函数 2)计算投资值函数格式:PV(表达式,n,m)说明:表达式指定每期付款金额;n指定年利率;m指定总期数。该函数用于计算投资金额的现值。3)计算本息和函数格式:FV(表达式,n,m)说明:表达式指定固定期的付款金额;n指定年利率;m指定固定期数值。该函数用于计算投资金额的未来利和。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-9年利率为12%,借期一年,总贷款数是15000元,每月应付款是多少?payment(15000,0.12/12,12)1332.72.4.3 转换函数转换函数转换函数可对某些数据的类型或某种属性进行转换。1.数

29、值转字串函数数值转字串函数格式:STR(表达式,n,m)说明:该函数用于将数值转换为数字字串。函数的返回值为字符型数据。其中:表达式指定拟转换的数值表达式;n指定转换后的宽度,包括小数位和小数点;m指定小数位数。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-10将数值型数据转换为字符数据并显示其转换结果。?str(123.456)123&隐含取整数部分转换为字符型数据?str(123.456,7,2)123.462.字符转数值函数字符转数值函数格式:VAL(表达式)说明:该函数用于将指定的字符数据转换为数值型数据。其中,表达式指定了拟转换的字符串。函数的返回值为数值型数据

30、。注意:要转换的字符表达式中必须包含有数字字符,否则将返回值0。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-11将数字字串转换为数值型数据。a=12B=13.45?val(a)+val(b)25.53.字符转日期函数字符转日期函数格式:CTOD(表达式)说明:该函数用于将字符表达式中的字符型日期转换为日期型数据,函数的返回值为日期型数据。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-12将字符型日期数据转换为日期型数据。Setdateansi&设置美国标准化协会日期格式?ctod(2000.1.12)2000.01.124.日期转字符函数日期转字符

31、函数格式:DTOC(表达式,1)说明:该函数用于将日期表达式中的日期转换为字符型日期数据,函数的返回值为字符型数据。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-13将日期型数据转换为字符型日期并显示汉字日期。rq=99.1.12rq=dtoc(rq)?subs(rq,1,2)+年+subs(rq,4,2)+月+subs(rq,7,2)+日99年01月12日第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.4.4 日期函数日期函数日期函数用于处理日期型数据,但日期函数的返回值不一定是日期型数据。1.系统日期函数系统日期函数格式:DATE()说明:该函数取系

32、统的当前日期,其返回值为日期型数据。例2-14显示系统当前日期和汉字日期。?date()2000/03/06setcenturyon&置显示日期的世纪前缀命令?date()2000/03/06第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.年、月、日函数年、月、日函数YEAR(日期表达式)该函数从日期表达中返回一个由四位数字表达的年份。MONTH(日期表达式)该函数从日期表达式中返回一个用数字表达的月份。DAY(日期表达式)该函数从日期表达式返回一个用数字表达的日数。值得注意的是:以上3个函数的返回值都是数值型数据,而非日期型数据。例2-15测试系统日期(年月日)。rq=da

33、te()?year(rq),month(rq),day(rq)2000.3.20第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.4.5 测试函数测试函数1.测试文件尾函数测试文件尾函数格式:EOF(表达式1|表达式2)说明:表达式1指定被测工作区号,其范围为1225;表达式2指定被测表的别名。EOF函数用于测试由区号或表别名所指定文件中的记录指针是否指向文件尾,如是则返回“真”值,否则返回“假”值。函数返回值为逻辑型数据。缺省可选项则测试当前工作区中的文件。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-16测试文件记录指针是否指向文件尾。Use学生档案G

34、obottom?eof().F.skip?eof().T.第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.测试文件头函数测试文件头函数格式:BOF(表达式1|表达式2)格式:表达式1指定被测工作区号,其范围为1225;表达式2指定被测表的别名。BOF函数用于测试由区号或表别名所指定文件中的记录指针是否指向文件头,如是则返回“真”值,否则返回“假”值。函数返回值为逻辑型数据。缺省可选项则测试当前工作区中的文件。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-17测试文件记录指针是否指向文件头。use学生档案?bof().F.skip-1?bof().T.值得

35、注意的是当打开无记录的空文件时,测试文件尾及文件头函数皆返回“真”值。如若被测试的文件不存在,以上两种测试都返回“假”值。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 3.测试当前记录号函数测试当前记录号函数格式:RECNO(表达式1|表达式2)说明:表达式1指定被测工作区号,其范围为1225;表达式2指定被测表的别名。RECNO函数测试由区号或表别名指定文件中的记录指针指向的记录号。缺省可选项则测试当前工作区中的文件。函数的返回值为数值型。若指定的工作区无打开的表文件,函数返回值为0;若指定的库文件无记录或记录指针位于文件头,函数返回值为1;若记录指针指向文件尾,函数返回值为

36、末记录号加1。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-18测试记录指针当前位置。Use学生档案Gobottom&指针移向末记录?recno()6skip&指针指向文件尾?recno()7gotop&指针指向首记录?recno()1skip1&指针指向文件头?recno()1第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 4.测试表文件记录数函数测试表文件记录数函数格式:RECCOUNT(表达式1|表达式2)说明:表达式1指定被测工作区号,其范围为1225;表达式2指定被测表的别名。RECCOUNT函数测试由区号或表别名指定文件中的记录数。缺省可选项时测

37、试当前工作区中的文件。函数返回值为数值型数据。若指定的工作区无打开的文件或打开的是只有结构而无记录的空文件,则返回值为0。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-18测试学生档案.DBF文件中记录数。Use学生档案?recount()65.测试字段名函数测试字段名函数格式:FIELD(n,表达式1|表达式2)说明:n指定被测字段序号;表达式1|表达式2 指定工作区号或表别名。FIELD函数测试由区号或表别名指定文件中指定序号的字段名。若指定的工作区无打开的表文件或指定字段号超界,函数返回空串(ASCII码为0)。第第2章章 常量、变量、表达式及函数常量、变量、表达式

38、及函数 例2-20测试学生档案.DBF表文件结构中第6号字段的字段名。Use学生档案?field(6)籍贯6.测试字段数函数测试字段数函数格式:FCOUNT(表达式1|表达式2)说明:表达式1指定被测工作区号,其范围为1225;表达式2指定被测表的别名。FCOUNT函数测试由区号或表别名指定文件中的文件记录数。缺省可选项时测试当前工作区中的文件。函数返回值为数值型数据。若指定的工作区无打开的表文件,则返回值为0。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-21测试学生档案.DBF库文件结构中的字段数。Use学生档案?fcount()87.测试查找记录是否成功函数测试查找

39、记录是否成功函数格式:FOUND(表达式1|表达式2)说明:表达式1指定被测工作区号,其范围为1225;表达式2指定被测表的别名。FOUND函数测试检索命令对区号或表别名指定文件的检索操作是否成功,成功则返回值为真,否则返回值为假。缺省可选项时,测试检索命令对当前工作区中文件的检索操作是否成功。常用的检索操作命令有:FIND、SEEK、LOCATE。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-22在学生档案.DBF文件中查询学生钱向冬的籍贯。Use学生档案Locatefor姓名=钱向冬?found(),籍贯.T.宁波市8.测试屏幕光坐标函数测试屏幕光坐标函数格式:ROW

40、()及COL()说明:前者测试光标所在行坐标,后者测试光标所在列坐标,返回值为数值型。例2-23在指定的屏幕坐标位置(10行,30列)显示“浙江万里学院”并测试显示后的光标位置。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 10,30say浙江万里学院row=row()col=col()?row,col10.00042.0009.测试打印机字头所在位置测试打印机字头所在位置格式:PROW()及PCOL()说明:前者测试打印机字头所在行坐标,后者为列坐标,返回值为数值型。例2-24在打印机字头当前坐标位置的下一行,列坐标加15的位置上打印“浙江万里学院”。prow()+1,pco

41、l()+15say浙江万里学院第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.4.6 键值函数键值函数键值函数的功能是根据按下的键返回相应的键值,下面介绍一个常用的键值函数。格式:INKEY(表达式1,表达式2)说明:表达式1指定等待按键的秒数,0值为无限等待。表达式2取值S、H、M,分别指定显示光标、隐藏光标及检查鼠标按键。INKEY函数返回所按键盘键或鼠标键的对应的键码值,常用键码值如表2.2所示。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 表2.2常用键码值第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 如果键入命令:?请按任意键:?in

42、key(10,H)则显示提示信息后面无光标显示,用户若在10秒内按键,则显示所按键的码值,否则到达10秒后函数返回0值。例2-25显示按键的码值。?请敲(、Esc、Enter、或其他键),inkey(10)第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.4.7 数组函数数组函数数组函数可完成对数组的操作,如数组间元素的复制、删除、查找和排序,本节仅介绍最常用数组函数AFIELDS。格式:AFIELDS(表达式表达式1|表达式2)说明:表达式数组名;表达式1工作区号;表达式2表别名。AFIELDS函数的功能是:将由工作区号或表别名指定的表文件结构信息存入指定数组中,并返回字段个

43、数。若指定数组不存在,系统会自动生成该数组。数组中的行对应于字段,列对应于字段名、字段类型、字段宽度和小数位数。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-26将学生档案.DBF的结构信息存入一数组中。use学生档案?afields(arrxsda)&将打开的表文件结构信息存入自动定义的数组中5&函数返回值为库文件的字段数listmemolikearrxsda&显示内存变量数组表文件结构主要信息显示如下:ARRHXSDAPudA(1,1)C学号(1,2)CC第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数(1,3)N4(4.00000000)(1,4)NO(

44、0.00000000)(2,1)C姓名(2,2)CC(2,3)N8(8.00000000)(2,4)N0(0.00000000)(3,1)C性别(3,2)CC(3,3)N2(2.00000000)(3,4)N0(0.00000000)第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数(4,1)C出生日期(4,2)CD(4,3)N8(8.00000000)(4,4)N0(0.00000000)(5,1)C籍贯(5,2)CC(5,3)N10(10.00000000)(5,4)N0(0.00000000)第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.4.8 其他函数其他

45、函数1.宏函数宏函数格式:&表达式表达式1说明:表达式指定字符型内存变量;表达式1指定字符型表达式。宏函数返回指定字符型内存变量中存放的字串或返回该字串与字符表达式字串连接后的字串。显然,宏函数的返回值为字符型。宏函数可以嵌套使用。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-27打开和删除临时指定的文件。28accept请输入文件名:towjm&字符型内存变量接收语句use&wjm&打开临时指定的表use&关闭打开的表erase&wjm.dbf&删除指定的表第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 2.条件函数条件函数格式:IIF(表达式,表达式1,

46、表达式2)说明:表达式指定逻辑表达式;表达式1指定第一个表达式;表达式2指定第二个表达式。IIF函数的功能是逻辑表达式取“真”值,则返回表达式1的值,否则返回表达式2的值。IIF函数可以嵌套。IIF函数返回值类型与表达式1或表达式2类型一致。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 例2-28根据查询成功与否,用IIF()函数显示的不同结果。Use学生档案locatefor姓名=钱向冬&查找定位Record=4&已找到,指针指向4号记录?iff(found(),籍贯,查无此人)&已找到,FOUND()取真值,返回此人的籍贯宁波市&籍贯为宁波市locatefor姓名=何晓月&

47、查找定位第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 EndofLocatescope&未找到,指针指向文件尾?iff(found(),籍贯,“查无此人”)&未找到,FOUND()取假值,返回查无此人查无此人&函数返回值3.用户自定义函数用户自定义函数FoxPro提供了功能丰富的系统函数,但系统函数的数量毕竟有限。为满足用户特殊需要和简化程序设计,系统还提供了用户自定义函数功能。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 定义用户自义函数的格式如下:FUNCTIONFunictionNamePARAMETERSParamemeterListCommandsRE

48、TURNExpression说明:FunctionName指定用户自定义函数名;PRAMETERS ParamemeterList声明自定义函数中使用的变量名(即形参表);Commands完成自定义函数功能的命令序列。RETURNeExpression指定函数返回值表达式。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 调用用户自定义函数格式如下:FunctionName(ParameterList)说明:FunctionName指定用户自定义函数名;ParameterList 指定调用函数的参数表(即实参表)。用户自定义函数也可作为过程被调用,此时将忽略函数的返回值。例2-29

49、设计一个汉字日期处理函数(HZRQCL)和一个调用程序(EXA2-29.PRG)。程序中安排采用两种不同的函数调用方式:函数调用方式和过程调用方式。第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 EXA2-29.PRG程序如下:ClearSetdateansiAccept请输入日期:torq?hzrqcl(rq)&函数方式调用accept请输入日期:torq1hzrq=space(14)dohzrqclwithrq1&过程方式调用第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数?hzrq用户自定义函数HZRQCL如下:FunctionhzrqclQarametersxHzrq=subs(x,1,2)+年+subs(x,4,2)+月+subs(x,7,2)+日Returnhzrq第第2章章 常量、变量、表达式及函数常量、变量、表达式及函数 程序执行结果如下:Doexa2_44请输入日期:2000.03.142000年03月14日请输入日期:2000.03.142000年03月14日因为用户自定义函数及其调用涉及知识较宽,读者在此不必深究,待以后逐步掌握。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁