2.数据类型、表达式和函数.ppt
《2.数据类型、表达式和函数.ppt》由会员分享,可在线阅读,更多相关《2.数据类型、表达式和函数.ppt(161页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、封面第二章 数据类型表达式和函数1 1 常量与变量常量与变量常量与变量常量与变量2.2.运算符与表达式运算符与表达式运算符与表达式运算符与表达式3.3.常用函数常用函数常用函数常用函数2.1 2.1 常量与变量常量与变量2.1.1 常量常量 常量常量是指操作是指操作过程中其程中其值固定不固定不变的数的数据,是一个具体的数据内容。据,是一个具体的数据内容。例如字符串、常数或具体的日期。例如字符串、常数或具体的日期。数值型常数数值型常数由数字由数字0-9、小数点及正、小数点及正负号构成号构成可用科学可用科学计数法表示数法表示:1.2345E+3表示表示1.2345103,即,即1234.5;2.4
2、5E-4表示表示2.4510-4,即,即0.000245 货币型常数货币型常数货币型常量表示型常量表示货币在数在数值前加上一个前加上一个货币符号符号($)。货币型常量在存型常量在存储和和计算算时,采用,采用4位位小数。当小数。当货币型常量超型常量超过4位小数位小数时,多余的小数位将四舍五入多余的小数位将四舍五入 字符常数字符常数字符型常量是用英文的单引号、双引号或方括号括起来的一串字符,也称为字符串。字符可以是英文字母、数字、标点符号等所有ASCII码字符及汉字。例如:湖南长沙、0731-8821234、smith都是字符串。字符常数字符常数单引号、双引号或方括号是字符串的引号、双引号或方括号
3、是字符串的定界符定界符定界符定界符,它它们用来用来规定字符串的起始和定字符串的起始和终止界限,不作止界限,不作为字符串本身的内容。字符串本身的内容。字符串的定界符必字符串的定界符必须成成对匹配,即当一匹配,即当一边以以单引号作引号作为定界符定界符时,另一,另一边也必也必须以以单引号作引号作为定界符。定界符。此外,如果字符串本身含有作此外,如果字符串本身含有作为定界符的字符,定界符的字符,则必必须用另一种符号作用另一种符号作为定界符。定界符。字符常数字符常数字符串的字符串的长度度是指字符串中所含字符的是指字符串中所含字符的个数,其中,每个个数,其中,每个汉字相当于字相当于2个字符。个字符。字符串
4、的最大字符串的最大长度不能超度不能超过254。只有定界符没有任何字符的字符串称只有定界符没有任何字符的字符串称为空串空串,其,其长度度为0。日期型日期型常数常数默默认情况下,日期型常量要使用情况下,日期型常量要使用严格的日期格式格的日期格式yyyy-mm-ddyyyy-mm-dd。以花括号以花括号 作作为定界符,花括号内第一个符号定界符,花括号内第一个符号是是,年份必,年份必须为四位,年月日的次序不能四位,年月日的次序不能颠倒倒或缺省。或缺省。年月日的分隔符可以年月日的分隔符可以为/(斜杠)、(斜杠)、_(下划(下划线)、)、.(圆点)或空格。点)或空格。例如,例如,2008-8-1 2008
5、/08/01 2008.8.1 2008 8 1均表示均表示2008年年8月月1日。日。日期型日期型常数常数若要若要设置置传统的日期格式,的日期格式,则应执行行SET SET STICTDATE TO 0STICTDATE TO 0命令。命令。默默认用用mm/dd/yy或或mm/dd/yyyy表示日表示日期常量。例如,期常量。例如,6/25/08或或6/25/2008均表均表示示2008年年6月月25日。日。若要恢复若要恢复为严格的日期格式,格的日期格式,执行行SET SET STICTDATE TO 1STICTDATE TO 1命令命令 提示本书在介绍命令时,约定方括号中的内容表示可选,竖
6、杠|分隔的内容表示任选其一,尖括号中的内容由用户提供。SET DATE TO SET DATE TO AMERICAN|ANSI|BRITISH|FRENCH|GERMAN|ITALIAN|JAPAN|USA|MDY|DMY|YMD设置日期的置日期的显示格式示格式,缺省格式缺省格式为AMERICAN,即,即mm/dd/yy。设置日期显示的格式设置日期显示的格式设置日期格式的参数设置日期格式的参数 短语格式短语格式短语格式YMDyy/mm/ddMDYmm/dd/yyDMYdd/mm/yyAMERICAN/USAmm/dd/yyANSIyy.mm.ddGERMANdd.mm.yyBRITISH/F
7、RENCHdd/mm/yyITALIANdd-mm-yyJAPANyy/mm/ddSET CENTURY ON/OFFSET CENTURY ON/OFF设置置显示日期示日期时是否是否显示世示世纪值。当使用当使用ONON,显示世示世纪值,即年号以,即年号以4 4位位显示;使示;使用用OFFOFF,不,不显示世示世纪值,即年号以,即年号以2 2位位显示。示。设置是否显示世纪值设置是否显示世纪值SET CENTURY OFF&设置2位数字年份SET DATE TO YMD&设置年月日格式?2008-6-1&显示结果为08/06/01SET STRICTDATE TO 0&设置不进行严格的日期格式检
8、查SET CENTURY ON&设置4位数字年份SET DATE TO DMY&设置日月年格式?2008-6-1,1/7/08&显示结果为01/06/2008和01/07/2008例题例题例题例题日期时间型常数日期时间型常数日期日期时间型常量包括日期和型常量包括日期和时间两部分两部分日期日期,时间。日期部分的格式和日期型常量相似,日期部分的格式和日期型常量相似,时间部分部分的格式的格式为HH:MM:SS A|P。HH、MM、SS分分别表示表示时、分、秒,、分、秒,A、P分分别表示上午和下午。表示上午和下午。时、分、秒可以缺省,默、分、秒可以缺省,默认值为12、0、0。A、P可以缺省,默可以缺省
9、,默认为上午。上午。注意:日期和注意:日期和时间之之间必必须用逗号或空格隔开。用逗号或空格隔开。2008-6-12008-6-1,表示表示20082008年年6 6月月1 1日上午日上午1212点(午夜)点(午夜)时间部分可以采取部分可以采取2424小小时制,当制,当时间大于或等于大于或等于1212,则自然表示下午。自然表示下午。例如,例如,2008-6-1 1:20:30 P2008-6-1 1:20:30 P和和2008-6-1 2008-6-1 13:20:3013:20:30均表示均表示20082008年年6 6月月1 1日下午日下午1 1点点2020分分3030秒秒日期时间型常数日期
10、时间型常数区域区域选项卡卡工具工具(T)(T)选项(O)(O)设置日期格式设置日期格式逻辑常数逻辑常数逻辑型常量只有型常量只有逻辑真和真和逻辑假两个假两个值。逻辑真真值用用.t.,.T.,.y.,.Y.表示,表示,逻辑假假值用用.f.,.F.,.n,.N.表示表示注意:注意:圆点作点作为逻辑型常量的定界符,型常量的定界符,必不可少。必不可少。2.1.2 2.1.2 内存变量内存变量分分为字段字段变量和内存量和内存变量量内存内存变量量:独立于数据表而存在,通常:独立于数据表而存在,通常用来存放命令操作或程序运行用来存放命令操作或程序运行过程中的程中的一些中一些中间结果。果。内存内存变量的量的值在
11、操作在操作过程中可以被改程中可以被改变。退出退出VFP后,内存后,内存变量将被自量将被自动释放。放。变量命名规则变量命名规则 变量名以字母、量名以字母、汉字或下划字或下划线开开头,由数,由数字、字母、字、字母、汉字或下划字或下划线组成。成。名称最名称最长可达可达254个字符。个字符。A、Class_2、年、年龄 合法的合法的变量名量名3Grade、b*非法的非法的变量名量名 不要使用不要使用VFP的保留字作的保留字作为变量名。量名。=STORE STORE TOTO 计算表达式的算表达式的值,再将,再将该值赋给内存内存变量。量。内存变量的赋值内存变量的赋值等号等号=一次只能一次只能给一个一个变
12、量量赋值,Store可同可同时给多多个个变量量赋同一个同一个值。多个。多个变量之量之间用逗号隔开。用逗号隔开。简单变量量赋值时无需事先声明或定无需事先声明或定义。当。当变量被量被赋值时,若,若该变量此量此时还不存在,系不存在,系统将建立此将建立此变量,量,即在内存中即在内存中为其定其定义一个存一个存储区域。区域。变量的量的值和数据和数据类型由最后型由最后赋予它的表达式决定。予它的表达式决定。当当变量被重新量被重新赋值时,其,其值发生改生改变。若新。若新值为其他其他数据数据类型,型,则变量的数据量的数据类型也相型也相应地地发生改生改变。内存变量的赋值内存变量的赋值 n1=3&把数值3赋给内存变量
13、n1,n1是数值型内存变量 name=王波王波&把字符串赋给内存变量name,name是字符型内存变量例题例题例题例题 store 2008/6/1 to 日期日期1,日期日期2&把日期常量2002年9月12日同时赋给内存变量日期1和日期2,日期1和日期2是日期型内存变量l=.t.&把逻辑真值.t.赋给内存变量l,l是逻辑 型内存变量 n2=n1&计算表达式n1的值为3,将n2赋值为3n1的值不受影响n2=n2+1&计算表达式n2+1的值为4,将n2赋值为4n2=n2+1&将字符串n2+1赋值给变量n2,n2是字符型内存变量例题例题例题例题?计算表达式的算表达式的值,将其,将其显示在窗口工作区
14、。示在窗口工作区。?命令首先命令首先换行,在当前行的下一行行,在当前行的下一行显示表达式的示表达式的值。?命令不命令不换行,在当前行的光行,在当前行的光标处显示表达式的示表达式的值。?/?/?可接多个表达式,表达式之可接多个表达式,表达式之间用逗号隔开。用逗号隔开。显示表达式的值显示表达式的值?n1=,n1&n1=为字符型常量,n1为变量,窗口工作区显示n1=3?n2&窗口工作区另起一行,显示n2+1?name&窗口工作区在n2+1的后面显示王波例题例题例题例题LIST/DISPLAY MEMORY LIST/DISPLAY MEMORY LIKE LIKE TO PRINTER|TO FIL
15、E TO PRINTER|TO FILE 显示内存变量的当前信息,包括变量名、作用域、类型、取值。内存变量的显示内存变量的显示使用LIST MEMORYLIST MEMORY,在屏幕上以滚动方式显示,不分屏显示;使用DISPLAY MEMORYDISPLAY MEMORY,分屏显示,即显示了一屏后,显示暂停,提示“按任意键继续”,按下任意键后,继续显示下一屏。内存变量的显示内存变量的显示LIKELIKE 通配符表示只显示与通配符相匹配的内 存变量。通配符*表示任一串字符,?表示任一个字符。VFP有74个系统变量。如果用户只要求显示所有自定义变量,可以使用命令DISPLAY MEMORY LIK
16、E*。内存变量的显示内存变量的显示TO PRINTERTO PRINTER子句,表示将显示的信息同时送打印机打印。TO FILETO FILE 子句,表示将显示的信息存入指定的文本文件,文件的扩展名为txt。内存变量的显示内存变量的显示display memo like*&显示用户定义的全部内存变量display memo like n*&显示以字母n开头的所有内存变量,即n1,name和n2 display memo like n?&显示以字母n开头,且名称不多于两个字符组成的内存变量 即n1和n2例题例题例题例题RELEASE RELEASE 清除内存变量内存变量的清除内存变量的清除REL
17、EASE RELEASE ALLALL LIKE LIKE|EXCEPT EXCEPT CLEAR MEMORYCLEAR MEMORY提示提示在输入命令时,命令中的保留字可只输入前4个字符。例如display memory 可简化为disp memo CLEAR MEMORYCLEAR MEMORYCLEAR MEMORYCLEAR MEMORY和RELEASE ALLRELEASE ALLRELEASE ALLRELEASE ALL清除内存中所有内存变量。RELEASE内存变量名表清除指定的内存变量。使用LIKE子句,清除符合通配符的变量;使用EXCEPT子句,清除不符合通配符的变量。内存
18、变量的清除内存变量的清除Release 日期日期1,日期日期2&清除变量日期1和日期2Release all like n*&清除所有变量名以n开始的变量,即n1,n2和name。Disp memo like*&此时,显示的变量有l例题例题例题例题2.1.3 2.1.3 数组数组内存内存变量又分量又分为简单内存内存变量量和和数数组。每一个每一个简单变量只占用内存中的一个存量只占用内存中的一个存储区域,存区域,存储一个一个值。而一个数而一个数组在内存中占用在内存中占用连续的一的一组存存储区域,由多个数区域,由多个数组元素元素组成。每个数成。每个数组元素占用一个存元素占用一个存储区域,相当于一个区
19、域,相当于一个简单变量。用量。用户通通过数数组名和下名和下标来来访问数数组元素。元素。DIMENSIONDIMENSION(,),DECLARE DECLARE(,),DIMENSION和DECLARE两种命令的功能相同,定义多个一维数组或二维数组数组的下标下限规定为1,一维数组的元素个数为下标上限1,二位数组的元素个数为下标上限1*下标上限2。数组的创建数组的创建DIMENSION m(4),n(2,3)命令定义了数组m和n。&m是一维数组,4个数组元素:m(1)、m(2)、m(3)、m(4)。&n是二维数组,有6个数组元素:n(1,1)、n(1,2)、n(1,3)、n(2,1)、n(2,2
20、)、n(2,3)。可以用一维数组的形式访问二维数组。例如二维数组n如果用一维数组表示,依次为n(1)、n(2)、n(3)、n(4)、n(5)、n(6)。即n(4)和n(2,1)是同一个数组元素。例题例题例题例题数组创建后,系统自动给每个元素赋以逻辑值假逻辑值假逻辑值假逻辑值假。通过对数组名赋值,可以将同一个值同时赋给全部的数组元素。每个数组元素可分别赋值,同一数组中各数组元素类型可以不同 数组的赋值数组的赋值DIMENSION m(4),n(2,3)&定义了一维数组m和二维数组n。?m(1),n(1,1)&数组创建后,每个数组元素的初值为逻辑值假。m=5&通过对数组名赋值将所有数组元素赋值为5
21、?m(1),m(2),m(3),m(4)n(1,1)=1n(1,2)=中国中国n(1,3)=2008/10/1&每个数组元素可分别赋值,数据类型可以不同例题例题例题例题2.2 2.2 运算符与表达式运算符与表达式表达式是由常量、变量、函数通过特定的运算符连结起来的有意义的式子。每一个表达式经过运算,将得到一个具体的结果,称为表达式的值。n1*0.85 +sqrt(9)变量变量运算符运算符常量常量函数函数表达式表达式根据表达式值的类型,可将表达式分为数值表达式、字符表达式、日期表达式和逻辑表达式。单个的常量、变量和函数,也可以看作一种特殊的表达式。2.2.1 数值型表达式数值型表达式()*或 (
22、乘方)2*4表示24 值为16*/%*/%(求余)10%3表示10除3的余数值为1+优优先先级级算数运算符算数运算符?1+52*2&结果为51。首先进行乘方运算,再进行乘法运算,最后进行加法。例题例题例题例题用表达式表示2*32+1.24+45?(2*32+1.2)/(4+4/5)&对于某些数学算式,注意利用括号来改变优先级例题例题例题例题对于求余运算,余数的正负号与除数相同?10%3,10%(-3),-10%3,-10%-3&结果为1,-2,-1,2 10-34余数为-210-3-3余数为1&表达式的值为-22.2.2 2.2.2 字符型表达式字符型表达式连接运算符+号:将前后两个字符串连接
23、起来,形成一个新的字符串。号:将前后两个字符串连接起来,若第一个字符串的尾部有空格,则将空格移到合并后字符串的尾部,其他位置的空格不改变位置。字符型运算符字符型运算符?“This“+”is”&表达式的结果为“This is”保留前一字符串的尾部空格?“This“-”is”&表达式的结果为“Thisis”将前一字符串的尾部空格移到最后?“This is“-”a book”&表达式的结果为“This isa book”例题例题例题例题?“2+3”,2+3,“2”+“3”&字符常量2+3 2与3相加为5 字符2连接字符3结果为23例题例题例题例题2.2.3 2.2.3 日期型表达式日期型表达式日期日
24、期1+天数天数 日期日期2 或天数或天数+日期日期1 日期日期2 将日期向后推整数的天数得到新的日期日期日期1天数天数 日期日期2将日期向前推整数的天数得到新的日期日期日期1日期日期2 整数整数+1将两个日期相减得到相差的天数排在后面的日期大于排在前面的日期日期型运算符日期型运算符日期日期时间1+1+秒数秒数 日期日期时间2 2 秒数秒数+日期日期时间1 1 日期日期时间2 2 将日期时间向后推整数的秒数得到新的日期时间日期日期时间1 1秒数秒数 日期日期时间2 2 将日期时间向前推整数的秒数得到新的日期时间日期日期时间1 1日期日期时间2 整数整数+1将两个日期时间相减得到相差的秒数排在后面
25、的日期大于排在前面的日期日期型运算符日期型运算符?2008/10/1+7&表达式的值为2008/10/8,将2008年10月1日向后推7天?2008/10/1-7&表达式的值为2008/9/24,将2008年10月1日向前推7天?2008/10/1-2008/5/1&表达式的值为153,两个日期相差的天数例题例题例题例题?2008-8-8 8 am+10000&表达式的值为2008年8月8日8点46分40秒,将2008年8月8日上午8时向后推10000秒的时间 例题例题例题例题注意:注意:+和-运算符必须遵循以上规则。例如,日期+日期就是一个非法的表达式。2.2.4 2.2.4 逻辑型表达式逻
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据类型 表达式 函数
限制150内