VBScript基础

基本简介 编辑

VBScript[2]是微软开发的一种解析型的服务端(也支持客户端)脚本语言,可以看作是VB语言的简化版,与VBA的关系也非常密切。它具有原语言容易学习的特性。目前这种语言广泛应用于网页和ASP程序制作,同时还可以直接作为一个可执行程序。用于调试简单的VB语句非常方便。

由于VBScript可以通过Windows脚本宿主调用COM,因而可以使用Windows操作系统中可以被使用的程序库,比如它可以使用Microsoft Office的库,尤其是使用MicrosoftAccess和Microsoft SQL Server的程序库,当然它也可以使用其它程序和操作系统本身的库。

Date/Time 函数

函数

描述

CDate 把有效的日期和时间表达式转换为日期(Date)类型
Date 返回当前的系统日期
DateAdd 返回已添加指定时间间隔的日期
DateDiff 返回两个日期之间的时间间隔数
DatePart 返回给定日期的指定部分
DateSerial 返回指定年,月,日的日期
DateValue 返回日期
Day 返回代表一月中的一天的数字(介于并包括,1,到,31,之间)
FormatDateTime 返回格式化为日期或时间的表达式
Hour 返回代表一天中的小时的数字(介于并包括,0,到,23,之间)
IsDate 返回指示计算表达式能否转换为日期的,布尔值
Minute 返回一个数字,代表小时的分钟(介于并包括,0,到,59,之间)
Month 返回一个数字,代表年的月份(介于并包括,1,到,12,之间)
MonthName 返回指定月份的名称
Now 返回当前的系统日期和时间
Second 返回一个数字,代表分钟的秒(介于并包括,0,到,59,之间)
Time 返回当前的系统时间
Timer 返回自,12:00,AM,以来的秒数
TimeSerial 返回特定小时,分钟和秒的时间
TimeValue 返回时间
Weekday 返回一个数字,代表一周的天数(介于并包括,1,到,7,之间)
WeekdayName 返回一周中指定的一天的星期名
Year 返回一个数字,代表年份
Conversion 函数

函数

描述

Asc 把字符串中的首字母转换为,ANSI,字符代码
CBool 把表达式转换为布尔(Boolean)类型
CByte 把表达式转换为字节(Byte)类型
CCur 把表达式转换为货币(Currency)类型
CDate 把有效的日期和时间表达式转换为日期(Date)类型
CDbl 把表达式转换为双精度(Double)类型
Chr 把指定的,ANSI,字符代码转换为字符
CInt 把表达式转换为整数(Integer)类型
CLng 把表达式转换为长整型(Long)类型
CSng 把表达式转换为,单精度,(Single)类型
CStr 把表达式转换为字符串(String)类型
Hex 返回指定数字的,十六进制,值
Oct 返回指定数字的,八进制,值
Format 函数

函数

描述

FormatCurrency 返回作为货币值进行格式化的表达式
FormatDateTime 返回作为日期或时间进行格式化的表达式
FormatNumber 返回作为数字进行格式化的表达式
FormatPercent 返回作为,百分数,进行格式化的表达式
Math 函数

函数

描述

Abs 返回指定数字的,绝对值
Atn 返回指定数字的反,正切
Cos 返回指定数字(角度)的,余弦
Exp 返回,e(自然,对数,的底)的幂次方
Hex 返回指定数字的十六进制值
Int 返回指定数字的整数部分
Fix 返回指定数字的整数部分
Log 返回指定数字的自然对数
Oct 返回指定数字的八进制值
Rnd 返回小于1但大于或等于0的一个随机数
Sgn 返回可指示指定数字的符号的一个整数
Sin 返回指定数字(角度)的,正弦
Sqr 返回指定数字的,平方根
Tan 返回指定数字(角度)的正切
Array 函数

函数

描述

Array 返回一个包含数组的变量
Filter 返回,下标,从零开始的数组,其中包含基于特定过滤条件的字符串数组的子集
IsArray 返回一个指示指定的变量是否为数组的布尔值
Join 返回一个由数组中若干子字符串组成的字符串
LBound 返回指示数组维数的最小下标
Split 返回下标从零开始的一维数组,包含指定数量的子字符串
UBound 返回指示数组维数的最大下标
String 函数

函数

描述

InStr 返回字符串在另一字符串中首次出现的位置,搜索从字符串的第一个字符开始
InStrRev 返回字符串在另一字符串中首次出现的位置,搜索从字符串的最末字符开始
LCase 把指定字符串转换为小写
Left 从字符串的左侧返回指定数量的字符
Len 返回字符串中的字符数量
LTrim 删除字符串左侧的,空格
RTrim 删除字符串右侧的空格
Trim 删除字符串左侧和右侧的空格
Mid 从字符串中返回指定数量的字符
Replace 使用另一个字符串替换字符串的指定部分指定的次数
Right 从字符串的右侧返回指定数量的字符
Space 返回由指定数量的空格组成的字符串
StrComp 比较两个字符串,返回代表比较结果的一个值
String 返回包含指定长度的重复字符的字符串
StrReverse 反转字符串
UCase 把指定的字符串转换为大写
其他函数 [3]

函数

描述

CreateObject 创建指定类型的对象
Eval 计算表达式,并返回结果
GetLocale 返回当前的,locale,ID
GetObject 返回对文件中,automation,对象的引用
GetRef 允许您把,VBScript,子程序连接到页面上的一个,DHTML,事件
InputBox 显示对话框,用户可在其中输入文本,并/或点击按钮,然后返回内容
IsEmpty 返回一个布尔值,指示指定的变量是否已被初始化
IsNull 返回一个布尔值,指示指定的表达式是否包含无效数据(Null)
IsNumeric 返回一个布尔值,指示指定的表达式是否可作为数字来计算
IsObject 返回一个布尔值,指示指定的表达式是否是一个,automation,对象
LoadPicture 返回一个图片对象,仅用于,32,位平台
MsgBox 显示消息框,等待用户点击按钮,并返回指示用户点击了哪个按钮的值
RGB 返回一个表示,RGB,颜色值的数字
Round 对数字进行,四舍五入
ScriptEngine 返回使用中的脚本语言
ScriptEngineBuildVersion 返回使用中的脚本引擎的内部,版本号
ScriptEngineMajorVersion 返回使用中的脚本引擎的主版本号
ScriptEngineMinorVersion 返回使用中的脚本引擎的次版本号
SetLocale 设置,locale,ID,并返回之前的,locale,ID
TypeName 返回指定变量的子类型
VarType 返回指示变量子类型的值

VBScriptVBScript 只有一种数据类型,称为 Variant。Variant 是一种特殊的数据类型,根据使用的方式,它可以包含不同类别的信息。因为 Variant 是 VBScript 中唯一的数据类型,所以它也是 VBScript 中所有函数的返回值的数据类型。

最简单的

最简单的 Variant 可以包含数字或字符串信息。Variant 用于数字上下文中时作为数字处理,用于字符串上下文中时作为字符串处理。这就是说,如果使用看起来象是数字的数据,则 VBScript 会假定其为数字并以适用于数字的方式处理。与此类似,如果使用的数据只可能是字符串,则 VBScript将按字符串处理。也可以将数字包含在引号 (" ") 中使其成为字符串。

子类型

简单数字或字符串以外,Variant 可以进一步区分数值信息的特定含义。例如使用数值信息表示日期或时间。此类数据在与其他日期或时间数据一起使用时,结果也总是表示为日期或时间。从 Boolean 值到浮点数,数值信息是多种多样的。Variant 包含的数值信息类型称为子类型。大多数情况下,可将所需的数据放进 Variant 中,而 Variant 也会按照最适用于其包含的数据的方式进行操作。

描述

Empty 未初始化的 Variant。对于数值变量,值为 0;对于字符串变量,值为零长度字符串 ("")。

Null 不包含任何有效数据的 Variant。

Boolean 包含 True 或 False。

Byte 包含 0 到 255 之间的整数。

Integer 包含 -32,768 到 32,767 之间的整数。

Currency -922,337,203,685,477.5808 到 922,337,203,685,477.5807。

Long 包含 -2,147,483,648 到 2,147,483,647 之间的整数。

Single 包含单精度浮点数负数范围从 -3.402823E38 到 -1.401298E-45,正数范围从 1.401298E-45 到 3.402823E38。

Double 包含双精度浮点数,负数范围从 -1.79 769 31348 6232E308 到 -4.9406564 5841247E-324,正数范围从 4.9406564 5841247E-324 到 1. 7976931 3486232E308。

Date (Time) 包含表示日期的数字,日期范围从公元 100 年 1 月 1 日到公元 9999 年 12 月 31 日。

String 包含变长字符串,最大长度可为 20 亿个字符。

Object 包含对象。

Error 包含错误号。

错误代码

Microsoft VBScript编译器错误 错误 '' 缺少语句

ActiveServerPages,ASP0126(0x80004005)-->找不到包含文件

MicrosoftOLEDBPRoviderforODBCDrivers(0x80040E21)-->sql语句出错(数据类型不匹配或表名(字段名)错误或表处于编辑状态,或表不存在于conn打开的数据库中)

MicrosoftOLEDBPRoviderforODBCDrivers(0x80040E14)-->sql语句出错(字段名错误,或数据类型不匹配)

MicrosoftOLEDBPRoviderforODBCDrivers(0x80040E07)-->sql语句出错(要插入或更新的字段的类型与变量数据类型不匹配)

MicrosoftOLEDBPRoviderforODBCDrivers(0x80040E57)-->sql语句出错(要插入或更新的数据溢出)

MicrosoftOLEDBPRoviderforODBCDrivers(0x80040E10)-->sql语句出错(update字段名或要更新的数据类型错误)

MicrosoftOLEDBPRoviderforODBCDrivers(0x80004005)-->sql语句出错(要插入或更新的字段的数值不能为空值)

MicrosoftOLEDBPRoviderforODBCDrivers(0x80004005) -->打开数据库出错,没有在指定目录发现数据库

MicrosoftOLEDBPRoviderforODBCDrivers(0x80040E37)-->没有发现表

MicrosoftVBscript运行时错误(0x800A000D)-->错误引用rs变量(rs对像已关闭或未定义)

MicrosoftVBscript运行时错误(0x800A01C2)-->vbscript脚本错误(vbscript语句出错)

MicrosoftVBscript运行时错误(0x800A0006)-->vbscript脚本错误(溢出错误)

MicrosoftVBscript编译器错误(0x800A040E)-->缺少loop

MicrosoftVBscript编译器错误(0x800A03EA)-->缺少if或endif

MicrosoftVBscript编译器错误(0x800A03EE)--> 语句未结束(缺少")")

MicrosoftVBscript编译器错误(0x800A03F6)-->if语句出错(缺少endif)

MicrosoftVBscript运行时错误(0x800A005B)-->缺少set

MicrosoftVBscript运行时错误(0x800A0005)-->变量未定义

MicrosoftVBscript编译器错误(0x800A03F9)-->if语句缺少then

MicrosoftVBscript编译器错误(0x800A0411)-->dim语句定义错误

MicrosoftVBscript编译器错误(0x800A0408)-->sql语句错误(?????????????????)

Microsoft VBScript 运行时错误 (0x800A01B6)错误原因:set rs=server.create......你少了 set

ADODB.Recordset(0x800A0BB9)-->sql语句出错(sql语句或conn语句未定义或对一个rs属性进行赋值时发生错误)

ADODB.Recordset(0x800A0CC1)-->rs对像出错(rs对像本身不存在或错误地引用了一个不存在的字段名)

ADODB.Recordset(0x800A0BCD)-->rs对像出错(记录集中没有记录却对记录集进行操作)

ADODB.Recordset(0x800A0E78)-->rs对像出错(记录集不存在,缺少rs.open语句)

ADODB.Recordset(0x800A0CC1) -->rs对像出错(引用了一个不存在的字段名)

ADODB.Recordset(0x800A0E7D)-->conn定义错误

ADODB.Recordset(0x800A0CB3)-->数据库以只读方式打开,无法更新数据

语法错误

如果 VBScript 语句结构违反了一个或多个 VBScript脚本语言语法规则,就会产生 VBScript 语法错误。

错误通常在执行程序前,编译程序时产生。 以下是53个语法错误:

错误编号 描述

十进制 十六进制 说明

1001 800A03E9内存不足

1002 800A03EA 语法错误

1003 800A03EB 缺少“:”

1005 800A03ED 需要 '('

1006 800A03EE 需要 ')'

1007 800A03EF 缺少“]”

1010 800A03F2 需要标识符

VBScript

1011 800A03F3 需要 '='

1012 800A03F4 需要 'If'

1013 800A03F5 需要 'To'

1014 800A03F6 需要 'End'

1015 800A03F7 需要 'Function'

1016 800A03F8 需要 'Sub'

1017 800A03F9 需要 'Then'

1018 800A03FA 需要 'Wend'

1019 800A03FB 需要 'Loop'

1020 800A03FC 需要 'Next'

1021 800A03FD 需要 'Case'

1022 800A03FE 需要 'Select'

1023 800A03FF 需要表达式

1024 800A0400 需要语句

1025 800A0401 需要语句的结束

1026 800A0402 需要整数常数

1027 800A0403 需要 'While' 或 'Until'

1028 800A0404 需要 'While,'、 'Until,' 或语句未结束

1029 800A0405 需要 'With'

1030 800A0406标识符太长

1031 800A0407 无效的数

1032 800A0408 无效的字符

1033 800A0409 未结束的串常量

1034 800A040A 未结束的注释

1037 800A040D 无效使用关键字'Me'

1038 800A040E 'loop' 没有 'do'

1039 800A040F 无效 'exit' 语句

1040 800A0410 无效 'for' 循环控制变量

1041 800A0411 名称重定义

1042 800A0412 必须为行的第一个语句

1043 800A0413 不能赋给非Byval参数

1044 800A0414 调用 Sub 时不能使用圆括号

1045 800A0415 需要文字常数

1046 800A0416 需要 'In'

1047 800A0417 需要 'Class'

1048 800A0418 必须在一个类的内部定义

1049 800A0419 在属性声明中需要 Let , Set 或 Get

1050 800A041A 需要 'PRoperty'

1051 800A041B 参数数目必须与属性说明一致

1052 800A041C 在类中不能有多个缺省的属性/方法

1053 800A041D 类初始化或终止不能带参数

1054 800A041E PRoperty Let 或 Set 至少应该有一个参数

1055 800A041F 不需要的 'Next'

1056 800A0420 只能在 ‘PRoperty’ 或 ’Function’ 或 ’Sub’ 上指定 ’Default’

1057 800A0421 说明 'Default' 必须同时说明 'Public' "

1058 800A0422 只能在 PRoperty Get 中指定 'Default'

运行错误

如果 VBScript脚本执行系统无法实施的操作,则会产生 VBScript 运行时错误。只有在运行脚本、为变量表达式赋值或

分配内存时,才会产生 VBScript 运行时错误。 以下是65个运行时错误:

错误编号 描述

十进制 十六进制 说明

5 800A0005 无效过程调用或参数

VBScript运行

6 800A0006 溢出

7 800A0007内存不足

9 800A0009下标越界

10 800A000A 该数组为定长的或临时被锁定

11 800A000B 被零除

13 800A000D类型不匹配

14 800A000E 字符串空间溢出

17 800A0011 无法执行请求的操作

28 800A001C堆栈溢出

35 800A0023 未定义 Sub 或 Function

48 800A0030 加载 DLL 错误

51 800A0033 内部错误

52 800A0034 坏文件名或数

53 800A0035 文件未找到

54 800A0036 坏文件模式

55 800A0037 文件已经打开

57 800A0039 设备I/O错误

58 800A003A 文件已经存在

61 800A003D 磁盘空间已满

62 800A003E 输入超出文件尾

67 800A0043 文件太多

68 800A0044 设备不可用

70 800A0046 权限禁用

71 800A0047 磁盘未准备好

74 800A004A 不能用不同的驱动器重新命名

75 800A004B路径/文件访问错误

76 800A004C 路径未找到

91 800A005B 未设置对象变量

92 800A005C For 循环未初始化

94 800A005E 非法使用 Null

322 800A0142 不能建立所需临时文件

424 800A01A8 需要对象

429 800A01AD ActiveX 部件无法创建对象

430 800A01AE类不支持自动化

VBScript 运行时错误432 800A01B0 在自动化操作中未找到文件名或类名

438 800A01B6 对象不支持该属性或方法

440 800A01B8 Automation错误

445 800A01BD 对象不支持此操作

446 800A01BE 对象不支持指定的参数

447 800A01BF 对象不支持当前的区域设置

448 800A01C0 未找到命名参数

449 800A01C1 参数不可选

450 800A01C2 错误的参数个数或无效的参数属性值

451 800A01C3 对象不是一个集合

453 800A01C5 指定的dll函数未找到

455 800A01C7 代码源锁错误

457 800A01C9 这个键已经是本集合的一个元素关联

458 800A01CA变量使用了一个 VBScript 中不支持的自动化(Automation)类型

462 800A01CE 远程服务器不存在或不能访问

481 800A01E1 无效图片

500 800A01F4 变量未定义

501 800A01F5 违法的分配

502 800A01F6脚本对象不安全

503 800A01F7 对象不能安全初始化

504 800A01F8 对象不能安全创建

505 800A01F9 无效的或不合格的引用

506 800A01FA 类未被定义

507 800A01FB 发生异常

5016 800A1398 需要正则表达式对象

5017 800A1399正则表达式中的语法错误

5018 800A139A 错误的数量词

5019 800A139B 在正则表达式中需要 ']'

5020 800A139C 在正则表达式中需要 ')'

5021 800A139D字符集越界

32811 800A802B 元素未找到

优点

VBScript

由于VBScript由网页浏览器解释执行,不需要增大服务器的负担。

易学。

在所有2000 / 98SE以后的Windows版本都可直接使用。

可以使用其它程序和可使用的物件(尤其MicrosoftOffice)。

缺点

现在VBS无法作为电子邮件的附件了。MicrosoftOutlook拒绝接受VBS为附件,收信人无法直接使用VBS附件。

VBS的各种编辑程器不受欢迎。

操作系统没有任何特别的保护设施。VBS程序与其它JS、EXE、BAT或CMD程序一样对待。操作系统没有监察恶意功能的能力。

操作系统

VBScript可以被用来自动地完成重复性Windows操作系统任务。在Windows操作系统中,VBScript可以在Windows Script Host的范围内运行。Windows操作系统可以自动辨认和执行*.VBS和*.WSF两种文件格式,此外 Internet Explorer可以执行HTA和CHM文件格式。VBS和WSF文件完全是文字式的,它们只能通过少数几种对话窗口与用户通讯。HTA和CHM文件使用HTML格式,它们的程序码可以象HTML一样被编辑和检查。在WSF、HTA和CHM文件中VBScript和JavaScript的程序码可以任意混合。HTA文件实际上是加有VBS、JavaScript成分的HTML文件。CHM文件是一种在线帮助,用户可以使用专门的编辑程序将HTML程序编辑为CHM。

网页浏览器

网页中的VBS可以用来指挥客户方的网页浏览器(浏览器执行VBS程序)。VBS与JavaScript在这一方面是竞争者,它们可以用来实现动态HTML,甚至可以将整个程序结合到网页中来。至今为止VBS在客户方面未能占优势,因为它只获得Microsoft Internet Explorer的支持(Mozilla Suite可以通过装置一个外挂来支持VBS)。而JavaScript则受到所有网页浏览器的支持。在Internet Explorer中VBS和JavaScript使用同样的权限,它们只能有限地使用Windows操作系统中的对象。

网页服务器

在网页服务器方面VBS是微软的Active Server Pages的一部分,它与JavaServer Pages和PHP是竞争对手。在这里VBS的程序码直接嵌入到HTML页内,这样的网页以ASP结尾。网页服务器Internet信息服务执行ASP页内的程序部分并将其结果转化为HTML传递给网页浏览器供用户使用。这样服务器可以进行数据库闻讯并将其结果放到HTML网页中。

脚本语言

是一种轻量级编程语言

VBScript 是微软的编程语言 Visual Basic 的轻量级的版本

如何工作

当VBScript 被插入一个 HTML 文档后,因特网浏览器会读取这个文档,并对 VBScript 进行解释。VBScript 可能会立即执行,也可能在之后的事件发生时执行。

读取 VBScript

1

2

3

4

5

6

7

8

9

<html>

<head>

</head>

<body>

document.write("Hello from VBScript!")

</script>

</body>

</html>

变量名称的规则

必须以字母开头

不能包含点号 (.)

不能超过 255 个字符

条件语句

经常地,当我们编写代码时,我们需要根据不同的判断执行不同操作。我们可以使用条件语句完成这个工作。

在 VBScript我们可以使用三种条件语句:

if 语句假如你希望在条件为 true 时执行一系列的代码,可以使用这个语句。

if...then...else 语句假如你希望执行两套代码其中之一,可以使用这个语句。

if...then...elseif 语句假如你希望选择多套代码之一来执行,可以使用这个语句。

select case 语句假如你希望选择多套代码之一来执行,可以使用这个语句。

例子

If....Then.....Else

在下面的情况中,您可以使用 If...Then...Else 语句:

在条件为 true 时,执行某段代码

选择两段代码之一来执行时

如果需要在条件为 true 时只执行一行语句,可以把代码写为一行:

1If i = 10 Then Msgbox "Hello"

在上面的代码中,没有 .else.. 语句。我们仅仅让代码在条件为 true 时执行一项操作(当 i 为 10 时)。

假如我们需要在条件为 true 时执行不止一条语句,那么就必须在一行写一条语句,然后使用关键词 "End If" 来结束这个语句:

1If i = 10 Then Msgbox "Hello" i = i + 1 End If

在上面的代码中,同样没有 .else.. 语句。我们仅仅让代码在条件为 true 时执行了多项操作。

假如我们希望在条件为 true 时执行某条语句,并当条件不为 true 时执行另一条语句,就必须添加关键词 "Else":

1

2

3

4

5

If i = 10 Then

Msgbox "Hello"

Else

Msgbox "Goodbye"

End If

当条件为 true 时会执行第一段代码,当条件不成立时执行第二段代码(当 i 不等于 10 时)。

If....Then.....Elseif

假如你希望选择多套代码之一来执行,可以使用if...then...elseif语句:

1

2

3

4

5

6

7

8

9

If payment = "Cash" Then

Msgbox "You are going to pay cash!"

ElseIf payment = "Visa" Then

Msgbox "You are going to pay with visa."

ElseIf payment = "AmEx" Then

Msgbox "You are going to pay with American Express."

Else

Msgbox "Unknown method of payment."

End If

Select Case

假如你希望选择多套代码之一来执行,可以使用 SELECT 语句:

1

2

3

4

5

6

7

8

9

10

Select Case payment

Case "Cash"

Msgbox "You are going to pay cash"

Case "Visa"

Msgbox "You are going to pay with visa"

Case "AmEx"

Msgbox "You are going to pay with American Express"

Case Else

Msgbox "Unknown method of payment"

End Select

以上代码的工作原理:首先,我们需要一个简单的表达式(常常是一个变量),并且这个表达式会被做一次求值运算。然后,表达式的值会与每个 case 中的值作比较,如果匹配,被匹配的 case 所对应的代码会被执行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值