加载中…
个人资料
  • 博客等级:
  • 博客积分:
  • 博客访问:
  • 关注人气:
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

Visual FoxPro 9.0 常用命令集锦

(2011-03-03 19:51:21)
标签:

杂谈

分类: 计算机技术

Visual FoxPro 9.0 常用命令集锦

一、 数值函数
数值函数用于数值运算,其自变量与函数都是数值型数据。
1.取绝对值函数ABS( )
【格式】ABS(<nExp>)
【功能】计算nExp的值,并返回该值的绝对值。
2.指数函数EXP( )
【格式】EXP(<nExp>)
【功能】求以e为底、nExp值为指数的幂,即返回ex的值。
3.取整函数INT( )
【格式】INT(<nExp>)
【功能】计算nExp的值,返回该值的整数部分。
4.上界函数CEILING( )
【格式】CEILING(<nExp>)
【功能】计算nExp的值,返回一个大于或等于该值的最小整数。
5.下界函数FLOOR( )
【格式】FLOOR(<nExp>)
【功能】计算nExp的值,返回一个小于或等于该值的最大整数。
6.自然对数函数LOG( )
【格式】LOG(<nExp>)
【功能】求nExp的自然对数。nExp的值必须为正数。
7.常用对数函数
【格式】LOG10(<nExp>)
【功能】求nExp的常用对数。nExp的值必须为正数。
8.平方根函数SQRT( )
【格式】SQRT(<nExp>)
【功能】求非负nExp的平方根。
9.最大值函数MAX( )和最小值函数MIN( )
【格式】MAX(<nExp1>,< nExp2>[,< nExp3>...])
MIN(<nExp1>,< nExp2>[,< nExp3>...])
【功能】返回数值表达式中的最大值MAX( )和最小值MIN( )。
10.求余数函数MOD( )
【格式】MOD(<nExp1>,<nExp2>)
【功能】返回nExp1除以nExp2的余数。余数的小数位数与nExp1相同,符号与nExp2相同。
11.四舍五入函数ROUND( )
【格式】ROUND(<nExp1>,< nExp2>)
【功能】返回nExp1四舍五入的值, nExp2表示保留的小数位数。
12.π函数PI( )
【格式】PI( )
【功能】返回常量π的近似值
13.正弦函数SIN( )
【格式】SIN(<nExp>)
【功能】返回nExp的正弦值。nExp以弧度为单位,函数值域为[-1,1]。
14.余弦函数COS( )
【格式】COS(<nExp>)
【功能】返回nExp的余弦值。nExp以弧度为单位,函数的值域为[-1,1]。
15.正切函数TAN( )
【格式】TAN(<nExp>)
【功能】返回nExp的正切值。nExp以弧度为单位,其值为π/2或- π/2时,系统返回一个绝对值很大的数。
16.反正弦函数ASIN( )
【格式】ASIN(<nExp>)
【功能】返回nExp的反正弦值。自变量值必须在[-1,1]内,函数值为弧度,且值域为[-π/2, π/2]。
17.反余弦函数ACOS( )
【格式】ACOS(<nExp>)
【功能】返回nExp的反余弦值。自变量的值必须在[-1,1]内,函数值为弧度,值域为[-π/2, π/2]。
18.反正切函数ATAN( )
【格式】ATAN(<nExp>)
【功能】返回nExp的反正切值。函数值为弧度,值域为(-π/2, π/2)。

二、 字符函数
字符函数是处理字符型数据的函数,其自变量或函数值中至少有一个是字符型数据。函数中涉及的字符型数据项,均以cExp表示。
1.子串位置函数
【格式】AT(<cExp1>,< cExp 2>)
【功能】返回串cExp1在串cExp2中的起始位置。函数值为整数。如果串cExp2不包含串cExp1,函数返回值为零。
2.取左子串函数LEFT( )
【格式】LEFT(<cExp>,<nExp>)
【功能】返回从cExp串中第一个字符开始,截取nExp个字符的子串。
3.取右子串函数RIGHT( )
【格式】RIGHT(<cExp >,< nExp>)
【功能】返回从cExp串中右边第一个字符开始,截取nExp个字符的子串。有关说明同LEFT( )函数。
4.取子串函数SUBSTR( )
【格式】SUBSTR (<cExp>,<nExp1> [,< nExp2>] )
【功能】返回从串cExp中第nExp1个字符开始,截取nExp2个字符的子串。
5.字符串长度函数LEN( )
【格式】LEN(<cExp>)
【功能】返回cExp串的字符数(长度)。函数值为N型。
6.删除字符串前导空格函数LTRIM( )
【格式】LTRIM(<cExp>)
【功能】删除cExp串的前导空格字符。
7.删除字符串尾部空格函数RTRIM( ) | TRIM( )
【格式】RTRIM | TRIM(<cExp>)
【功能】删除cExp串尾部空格字符。
8.空格函数SPACE( )
【格式】SPACE (<nExp>)
【功能】返回一个包含nExp个空格的字符串。
9.字符串替换函数STUFF( )
【格式】STUFF(<cExp1>,<nExp1>,<nExp2>,<cExp2>)
【功能】从nExp1指定位置开始,用cExp2串替换 cExp1串中nExp2个字符。
10.字符复制函数 REPLICATE( )
【格式】REPLICATE (<cExp>,<nExp>)
【功能】返回将cExp串重复nExp次的字符串。
11.定义输出格式函数 TRANSFORM( )
【格式】TRANSFORM (<eExp>,<cExp>)
【功能】按格式描述式cExp指定的格式,输出任意表达式eExp的值。
12.大小写转换函数LOWER( ) 和UPPER( )
【格式】LOWER (<cExp>)
UPPER (<cExp>)
【功能】LOWER( )将cExp串中字母全部变成小写字母,UPPER( )将cExp串中字母全部变成大写字母,其它字符不变。
13.宏替换函数 &
【格式】& < cVar >[.< cExp >]
【功能】替换出字符型变量cVar中字符。

三、 日期时间函数
日期时间函数是处理日期型或日期时间型数据的函数。其自变量为日期型表达式dExp或日期时间型表达式tExp。
1.系统日期函数DATE( )
【格式】DATE()
【功能】返回当前系统日期,此日期由Windows系统设置。函数值为D型。
2.系统时间函数TIME( )
【格式】TIME([<nExp>])
【功能】返回当前系统时间,时间显示格式为hh:mm:ss。若选择了nExp ,则不管为何值,返回的系统时间还包括秒的小数部分,精确至小数点后两位。函数值为C型。
3.日期函数DAY( )
【格式】DAY(<dExp>)
【功能】返回dExp式中的天数。函数值为N型
4.星期函数DOW( )、CDOW( )
【格式】DOW(<dExp>)
CDOW(<dExp>)
【功能】DOW( )函数返回dExp式中星期的数值,用1~7表示星期日~星期六。函数值为N型。CDOW( ) 函数返回dExp式中星期的英文名称。函数值为C型。
5.月份函数MONTH( )、CMONTH( )
【格式】MONTH(<dExp>)
CMONTH(<dExp>)
【功能】MONTH( )函数返回dExp式中月份数。函数值为N型。CMONTH( )函数则返回月份的英文名。函数值为C型。
6.年份函数YEAR( )
【格式】YEAR(<dExp>)
【功能】函数返回dExp式中年份值。函数值为N型。

四、转换函数
在数据库应用的过程中,经常要将不同数据类型的数据进行相应转换,满足实际应用的需要。Visual FoxPro系统提供了若干个转换函数,较好地解决了数据类型转换的问题。
1.ASCII码函数ASC( )
【格式】ASC (<cExp>)
【功能】返回cExp串首字符的ASCII码值。函数值为N型。
2.ASCII字符函数CHR( )
【格式】CHR(<nExp >)
【功能】返回以nExp值为ASCII码的ASCII字符。函数值为C型。
3.字符日期型转换函数CTOD( )
【格式】CTOD(<cExp>)
【功能】把“××/××/××”格式的cExp串转换成对应日期值。函数值为D型。
4.日期字符型转换函数DTOC( )
【格式】DTOC(<dExp >[, 1])
【功能】把日期dExp转换成相应的字符串。函数值为C型。
5.数值字符型转换函数STR( )
【格式】STR(<nExp1>[,< nExp2>][,< nExp3>])
【功能】将nExp1的数值转换成字符串形式。函数值为C型。
6.字符数值型转换函数VAL( )
【格式】VAL (<cExp>)
【功能】将cExp串中数字转换成对应数值,转换结果取两位小数。函数值为N型。

五、 测试函数
在数据库应用的操作过程中,用户需要了解数据对象的类型、状态等属性,Visual FoxPro提供了相关的测试函数,使用户能够准确地获取操作对象的相关属性。
1.数据类型函数TYPE( )
【格式】TYPE(<cExp >)
【功能】返回cExp 串表示的数据对象的数据类型,返回值是一个表示数据类型的大写字母。C:字符型,D:日期型,N:数值型,L:逻辑型,M:备注型,G:通用型,U:未定义。
2.文件查找函数FILE()
【格式】FILE(<cExp>)
【功能】根据cExp串中指定路径查找文件,如未指定路径,则在默认目录中查找。文件存在,返回逻辑真(.T.) 值,否则为逻辑假(.F.)值。
3.条件测试函数IIF( )
【格式】IIF(<lExp >,<eExp 1>,<eExp2>)
【功能】逻辑表达式lExp值为真(.T.),返回表达式eExp1的值,否则返回表达式eExp2的值。eExp1和eExp2可以是任意数据类型的表达式。
4.表结束标志测试函数EOF( )
【格式】EOF([<工作区号> | <别名>])
【功能】测试记录指针是否移到表结束处。如果记录指针指向表中尾记录之后,函数返回真(.T.),否则为假(.F.)。
5.表起始标识测试函数BOF ( )
【格式】BOF ([<工作区号> | <别名>])
【功能】测试记录指针是否移到表起始处。如果记录指针指向表中首记录前面,函数返回真(.T.),否则为假(.F.)。工作区说明见EOF()函数。
6.当前记录号函数RECNO()
【格式】RECNO([<工作区号> | <别名>])
【功能】返回指定工作区中表的当前记录的记录号。对于空表返回值为1。
7.当前记录逻辑删除标志测试函数DELETED( )
【格式】DELETED([<工作区号> | <别名>])
【功能】测试指定工作区中表的当前记录是否被逻辑删除。如果当前记有逻辑删除标记,函数返回真(.T.),否则为假(.F.)。
8.记录数函数RECCOUNT( )
【格式】RECCOUNT ([<工作区号> | <别名>])
【功能】返回指定工作区中表的记录个数。如果工作区中没有打开表则返回0。
9.记录大小测试函数RECSIZE( )
【格式】RECSIZE( [<工作区号> | <别名>] )
【功能】返回指定工作区中表的记录总长度。如果工作区中没有打开表则返回0。
10.屏幕列坐标和行坐标函数 COL( )、ROW( )
【格式】COL ( )
ROW()
【功能】COL ( )返回光标的列坐标值,ROW ( )返回光标的行坐标值。
11.打印机列坐标和行坐标函数PCOL( ),PROW( )
【格式】PCOL( )
PROW()
【功能】返回打印机打印头所处位置的列坐标和行坐标。

 

ABS():返回一个数值表达式的绝对值。

语法:ABS(数值表达式)

返回值:数据型

示例

?ABS(5),ABS(-5) &&返回结果均为:5

ALLTRIM():去掉字符型表达式开头和结尾的空格。

语法:ALLTRIM(字符表达式)

返回值:字符型

示例

cString=”   Visual FoxPro  
?ALLTRIM(cString)        &&返回结果为”Visual FoxPro”

ASC():返回字符串左边第一个字符的ANSI值。

语法:ASC(字符表达式)

返回值:数值型

示例

?ASC('abcdef') &&返回结果为:97

AT():返回字符串1在字符串2中首次出现的位置。

语法:AT(cSearchExpression, cExpressionSearched [, nOccurrence])
      cSearchExpression:字符串1;cExpressionSearched:字符串2;
      nOccurrence:指定出现的次数(第一次,第二次)

返回值:数值型

示例

STORE 'Now is the time for all good men' TO gcString
STORE 'is the' TO gcFindString
CLEAR
? AT(gcFindString,gcString) && 显示5
STORE 'IS' TO gcFindString
? AT(gcFindString,gcString) && 显示0

ATC():返回字符串1在字符串2中首次出现的位置。字母不分大小写。

其他同AT()

BETWEEN():返回一个表达式的值是否在两个给定的值之间。

语法:BETWEEN(eTestValue, eLowValue, eHighValue)

返回值:逻辑型或NULL

说明:三个参数的类型必须相同

示例

?BETWEEN(8,6,9) &&返回结果为.T.
?BETWEEN({2/14/2000},{1/1/1999},{1/1/2001}) &&返回结果为.T.

BOF():查看表指针是否指向记录的开始标志。

语法:BOF([工作区号|别名])

返回值:逻辑型

CDOW():以字符的形式返回日期(时间)型表达式是星期几(Day-Of-Week)。

语法:CDOW(日期表达式| 日期时间表达式)

返回值:字符型

示例

dVar={10/01/2001}
?CDOW(dVar)          &&显示“Monday”

CHR():返回给定ASCII值所对应的字符。

语法:CHR(ASCII值)

返回值:字符型

示例

?CHR(65)        &&显示字符“A”

CMONTH():以字符的形式返回日期(时间)型表达式的月份。

语法:CMONTH(日期表达式|日期时间表达式)

返回值:字符型

示例

?CMONTH({10/01/2001})   &&显示“October”

CTOD():将字符型转成日期型。

语法:CTOD(字符表达式)

返回值:日期型

示例

STORE '7/4/1776' TO gcthe_4th
CLEAR
? CTOD(gcthe_4th)
STORE DATE( ) TO gdtoday
STORE CTOD('12/25/95') TO gdchristmas
STORE STR(gdchristmas - gdtoday, 4) TO gddays_left
? 'There are', gddays_left, 'days until Christmas'

DATE():返回系统当前日期。

语法:DATE()

返回值:日期型

DATETIME():返回系统当前日期时间。

语法:DATETIME()

返回值:日期时间型

DAY():返回一个日期(时间)型表达式中的“日”。

语法:DAY(日期表达式| 日期时间表达式)

返回值:数值型

示例

?DAY({10/01/2001})   &&显示为1

DOW():以序号形式返回一个日期是星期几,星期天为1,星期一为2……

语法:DOW(日期表达式| 日期时间表达式)

返回值:数值型

示例

?DOW({10/01/2001})    &&显示为2

DTOC():将日期型转换成字符型。

语法:DTOC(日期表达式| 日期时间表达式[, 1])

返回值:字符型

示例

STORE CTOD('10/31/95') TO gdThisDate
CLEAR
? DTOC(gdThisDate)      &&显示为“10/31/95”
STORE DTOC({10/31/95}+90) TO gcExpireDate
? 'Your 90-day warranty expires ', gcExpireDate
? DTOC({10/31/95},1)    &&显示为“19951031”

EMPTY():测试一个表达式的值是否为空。对字符型而言,空串和空格串为空;数值型、整型、浮点型、双精度型及货币型中0即为空;空日期和空日期时间也是空。

语法:EMPTY(表达式)

返回值:逻辑型

EOF():测试表指针是否指向记录的结束标志。

语法:EOF([工作区号| 别名])

返回值:逻辑型

FCOUNT():返回已打开的表中的字段总数。

语法:FCOUNT([工作区号| 别名])

返回值:数值型

FIELD():返回一个表中指定序号的字段名。

语法:FIELD(字段序号[, 工作区号| 别名])

返回值:字符型

示例

USE xs
FOR gnCount = 1 TO FCOUNT( ) 
    ? FIELD(gnCount)              &&显示每个字段名 
NEXT

GETCOLOR():打开系统的“颜色”对话框。结果是一颜色值。

语法:GETCOLOR()

返回值:数值型

GETDIR():打开系统的“选定目录”对话框。结果是选定的文件夹的路径。

语法:GETDIR()

返回值:字符型

GETFILE():打开系统的“打开”对话框。结果为选定的文件及其路径。

语法:GETFILE()

返回值:字符型

GETFONT():打开系统的“字体”对话框。结果为所选定的字体、字形、字号。

语法:GETFONT()

返回值:字符型

HOUR():返回一个日期时间表达式中的小时。

语法:HOUR(日期时间表达式)

返回值:数值型

IIF():如果条件成立则返回第一个表达式的值,否则返回第二个表达式的值。

语法:IIF(条件, 表达式1, 表达式2)

返回值:字符型、数值型、日期型、日期时间型、货币型

示例

a=7
b=8
?IIF(a>b,"真","假")      &&结果为“假”
a=17
?IIF(a>b,"真","假")      &&结果为“真”

INT():取一个数值型表达式的整数部分。

语法:INT(数值表达式)

返回值:数值型

? INT(12.5)         && 显示 12
? INT(6.25 * 2)     && 显示 12
? INT(-12.5)        && 显示 -12
STORE -12.5 TO gnNumber
? INT(gnNumber)     && 显示 -12

LEFT():返回一个字符表达式结果左边的若干字符。

语法:LEFT(字符表达式, 数值表达式)

返回值:字符型

示例

? LEFT('Redmond, WA', 4)     && 显示 “Redm”

LEN():返回一个字符串的长度。

语法:LEN(字符表达式)

返回值:数值型

LOWER():将字符串所有的大写字母转换成小写。

语法:LOWER(字符表达式)

返回值:字符型

LTRIM():去掉字符串左边(首部)的空格。

语法:LTRIM(字符表达式)

返回值:字符型

MAX():返回若干个表达式中的最大值。

语法:MAX(表达式1, 表达式2[, 表达式3...])
返回值:字符型、数据值、日期(时间)型、货币型、双精度型

说明:各表达式的类型须一致。

MESSAGEBOX():显示一个对话框。(详见学习指导书P.40~42)

语法:MESSAGEBOX(提示信息内容[, 按钮及图标类型[, 标题文本]])

返回值:数值型

MIN():返回若干个表达式中的最小值。

语法:MIN(表达式1, 表达式2[, 表达式3...])
返回值:字符型、数据值、日期(时间)型、货币型、双精度型

说明:各表达式的类型须一致。

MINUTE():返回一个日期时间型表达式中的分钟值。

语法:MINUTE(日期时间表达式)

返回值:数值型

MOD():计算一个整数整另一个整数后所得的余数。

语法:MOD(被除数, 除数)

返回值:数值型

说明:结果和除数同号;若被除数与除数同号则表示余几个,若异号则表示差几个。

示例

?MOD(18,5)         &&结果为 3
?MOD(18,-5)        &&结果为 -2
?MOD(-18,-5)       &&结果为 -3
?MOD(-18,5)        &&结果为 2

MONTH():返回一个日期(时间)表达式中的月份。

语法:MONTH(日期表达式| 日期时间表达式)
返回值:数值型

PUTFILE():打开系统的“另存为”对话框。结果为输入的文件名及其路径。

语法:PUTFILE([提示文本] [, 文件名] [, 扩展名])

返回值:字符型

RAND():返回一个0~1之间的随机数。

语法:RAND([种子数])

返回值:数值型

RECNO():返回指定工作区中表的当前记录号。

语法:RECNO([工作区号| 别名])
返回值:数值型

RGB():返回一个由红、绿、蓝三种颜色组成的颜色。

语法:RGB(红色值,绿色值, 蓝色值)

说明:三种颜色的值均在0~255之间。

RIGHT():返回一个字符串右边的若干字符。

语法:RIGHT(字符表达式, 数值表达式)

返回值:字符型

示例

? RIGHT('Redmond, WA', 2)    && 显示“WA”

ROUND():返回一个在指定小数位上四舍五入后的数。

语法:ROUND(数值表达式, 小数位)

返回值:数值型

示例

? ROUND(1234.1962, 3)     && 显示 1234.1960
? ROUND(1234.1962, 2)     && 显示 1234.2000
? ROUND(1234.1962, 0)     && 显示 1234.0000
? ROUND(1234.1962, -1)    && 显示 1230.0000
? ROUND(1234.1962, -2)    && 显示 1200.0000
? ROUND(1234.1962, -3)    && 显示 1000.0000

RTRIM():去掉字符串右边(首部)的空格。

语法:RTRIM(字符表达式)

返回值:字符型


SPACE():返回一定数量的空格。

语法:SPACE(数值表达式)

返回值:字符型

STR():将数值型转换成字符型。

语法:STR(数值表达式[, 长度[, 小数位数]])

返回值:字符型

示例

nVar=123.456
?STR(nVar)            &&结果为 “       123”,长度为10
?STR(nVar,8)          &&结果为 “     123”,长度为8
?STR(nVar,8,2)        &&结果为 “  123.46”,长度为8,小数位为两位。

SUBSTR():在一个字符串中从指定位置起返回给定长度的子串。

语法:SUBSTR(字符表达式, 起点位置[, 长度])

返回值:字符型

示例

STORE 'abcdefghijklm' TO mystring
? SUBSTR(mystring, 1, 5)          && 结果为 “abcde”
? SUBSTR(mystring, 6)             && 结果为 “ fghijklm”

TYPE():返回一个常量、变量或表达式的数据类型。

语法:TYPE(字符表达式)
返回值:字符型

说明:结果以一个字母返回,具体每一种数据类型的字母在教材第二章上有。

TRIM():同RTRIM()。

UPPER():将字符串中小写字母转换成大写。

语法:UPPER(字符表达式)

返回值:字符型

USED():测试指定的表是否被打开。

语法:USED([工作区号| 别名])
返回值:逻辑型

VAL():将字符型的数字转换成数值。

语法:VAL(字符表达式)

返回值:数值型

STORE '12' TO A
STORE '13' TO B
? VAL(A) + VAL(B)        && 结果为 25.00
STORE '1.25E3' TO C
? 2 * VAL(C)             && 结果为 2500.00

YEAR():返回一个日期(时间)型数据中的年份。

语法:YEAR(日期表达式| 日期时间表达式)

返回值:数值型

0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有