iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >VBS脚本中的字典、动态数组、队列和堆栈如何实现
  • 669
分享到

VBS脚本中的字典、动态数组、队列和堆栈如何实现

2023-06-08 09:06:18 669人浏览 独家记忆
摘要

这篇文章给大家分享的是有关VBS脚本中的字典、动态数组、队列和堆栈如何实现的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1.编写环境今天突发奇想下载了个gVim来写VBS脚本,我用的版本是7.4的在写脚本前,需要

这篇文章给大家分享的是有关VBS脚本中的字典、动态数组、队列和堆栈如何实现的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

1.编写环境

今天突发奇想下载了个gVim来写VBS脚本,我用的版本是7.4的

在写脚本前,需要在gVim的安装根目录下,找到文件“_vimrc”,在里面添加下面三行:

set number
set softtabstop=4
set tabstop=4

意思分别是“显示行号”、“按退格键一次删掉4个空格”和“设定Tab长度为4个字符”

这个设置类似于linux系统下文件“.vimrc”的配置

1.字典:Scripting.Dictionary

VBS中的字典需要使用Scripting.Dictionary

脚本文件:a.vbs,包含字典的添加、删除、判断键是否存在、修改键、修改值、遍历、统计键值对个数

Option Explicit'建立字典Dim Dict : Set Dict = CreateObject("Scripting.Dictionary")'添加键值对Dict.Add "Key1", "Item1"Dict.Add "Key2", "Item2"Dict.Add "Key3", "Item3"'字典中键值对数量WScript.Echo "字典中现有键值对数量: " & Dict.CountWScript.Echo '检查指定键是否存在If Dict.Exists("Key1") Then  WScript.Echo "Key1 存在!"Else  WScript.Echo "Key1 不存在!"End IfIf Dict.Exists("Keyn") Then  WScript.Echo "Keyn 存在!"Else  WScript.Echo "Keyn 不存在!"End IfWScript.Echo '遍历字典Sub TraverseDict  Dim DicTKEys, DictItems, Counter  DictKeys = Dict.Keys  DictItems = Dict.Items  For Counter = 0 To Dict.Count - 1    WScript.Echo _      "键: " & DictKeys(Counter) & _      "值: " & DictItems(Counter)  NextEnd SubTraverseDictWScript.Echo '在一个键值对中,修改键或修改值Dict.Key("Key2") = "Keyx"Dict.Item("Key1") = "Itemx"TraverseDictWScript.Echo '删除指定键Dict.Remove("Key3")TraverseDictWScript.Echo '删除全部键Dict.RemoveAllWScript.Echo "字典中现有键值对数量: " & Dict.Count

调用方法:通过双击a.bat调用,a.bat代码如下:

cscript a.vbs
pause

运行结果截图:

VBS脚本中的字典、动态数组、队列和堆栈如何实现

2.动态数组:System.Collections.ArrayList

VBS中的动态数组需要使用System.Collections.ArrayList

脚本文件:b.vbs,包含动态数组的添加元素、删除元素、遍历、统计元素个数、清空

Option Explicit'建立动态数组Dim Arrl : Set Arrl = CreateObject("System.Collections.ArrayList")'添加元素Arrl.Add "Element3"Arrl.Add "Element2"Arrl.Add "Element1"'查看动态数组中的元素数WScript.Echo "动态数组中现有元素数量: " & Arrl.CountWScript.Echo "动态数组容量: " & Arrl.CapacityWScript.Echo'遍历动态数组Sub TraverseArrl  Dim Counter  For Counter = 0 To Arrl.Count - 1    WScript.Echo Arrl(Counter)  NextEnd SubTraverseArrlWScript.Echo'动态数组排序Arrl.SortTraverseArrlWScript.Echo'删除指定元素Arrl.Remove("Element1")TraverseArrlWScript.Echo'清空全部元素Arrl.ClearWScript.Echo "动态数组中现有元素数量: " & Arrl.CountWScript.Echo "动态数组容量: " & Arrl.Capacity

调用方法:通过双击b.bat调用,b.bat代码如下:

cscript b.vbs
pause

运行结果截图:

 VBS脚本中的字典、动态数组、队列和堆栈如何实现

3.队列:System.Collections.Queue

VBS中的队列需要使用System.Collections.Queue

脚本文件:c.vbs,包含队列的添加元素(入队)、删除元素(出队)、遍历、统计元素个数、清空

Option Explicit'建立队列Dim Que : Set Que = CreateObject("System.Collections.Queue")Que.EnQueue("Element1")Que.EnQueue("Element2")Que.EnQueue("Element3")'查看队列中的元素数WScript.Echo "队列中的元素数: " & Que.CountWScript.Echo'遍历队列Sub TraverseQue  Dim ArrQue : ArrQue = Que.ToArray  Dim Counter  For Counter = 0 To UBound(ArrQue)    WScript.Echo ArrQue(Counter)  NextEnd SubTraverseQueWScript.Echo'退出队列WScript.Echo Que.DeQueueWScript.Echo "---"TraverseQueWScript.Echo'清空队列Que.ClearWScript.Echo "队列中的元素数: " & Que.Count

调用方法:通过双击c.bat调用,c.bat代码如下:

cscript c.vbs
pause

运行结果截图:

VBS脚本中的字典、动态数组、队列和堆栈如何实现

4.堆栈:System.Collections.Stack

VBS中的堆栈需要使用System.Collections.Stack

脚本文件:d.vbs,包含堆栈的添加元素(压栈)、删除元素(出栈)、遍历、统计元素个数、清空 

Option Explicit'建立堆栈Dim Stk : Set Stk = CreateObject("System.Collections.Stack")Stk.Push "Element1"Stk.Push "Element2"Stk.Push "Element3"'查看堆栈中的元素数WScript.Echo "堆栈中的元素数: " & Stk.CountWScript.Echo'遍历堆栈Sub TraverseStk  Dim ArrStk : ArrStk = Stk.ToArray  Dim Counter  For Counter = 0 To UBound(ArrStk)    WScript.Echo ArrStk(Counter)  NextEnd SubTraverseStkWScript.Echo'元素出栈WScript.Echo Stk.PopWScript.Echo "---"TraverseStkWScript.Echo'清空堆栈Stk.ClearWScript.Echo "堆栈中的元素数: " & Stk.Count

 调用方法:通过双击d.bat调用,d.bat代码如下:

cscript d.vbs
pause

运行结果截图:

VBS脚本中的字典、动态数组、队列和堆栈如何实现

可以看出,遍历队列和堆栈时,遍历顺序时由出队和出栈的顺序决定的,而不是入队和压栈的顺序

感谢各位的阅读!关于“VBS脚本中的字典、动态数组、队列和堆栈如何实现”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

--结束END--

本文标题: VBS脚本中的字典、动态数组、队列和堆栈如何实现

本文链接: https://www.lsjlt.com/news/253091.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mysql毫秒时间戳转时间怎么实现
    在MySQL中,可以使用FROM_UNIXTIME()函数将毫秒时间戳转换为时间。需要注意的是,FROM_UNIXTIME()函数接...
    99+
    2024-05-14
    mysql
  • mysql创建序列的方法是什么
    MySQL并没有内置的序列功能,但可以通过创建一个表来模拟序列的功能。以下是一种创建序列的方法: 创建一个表来存储序列的当前值: ...
    99+
    2024-05-14
    mysql
  • mysql怎么修改自增列的初始值
    要修改MySQL表中自增列的初始值,可以使用ALTER TABLE语句。以下是一个示例: ALTER TABLE table_nam...
    99+
    2024-05-14
    mysql
  • MySQL如何设置自增初始值
    在MySQL中,可以使用AUTO_INCREMENT关键字来设置自增初始值。可以使用以下语法来设置自增初始值: ALTER TABL...
    99+
    2024-05-14
    mysql
  • oracle怎么设置主键自增
    在Oracle数据库中,可以通过序列(Sequence)和触发器(Trigger)来实现设置主键自增的功能。 首先,需要创建一个序列...
    99+
    2024-05-14
    oracle
  • pgsql删除索引的方法是什么
    要删除一个索引,可以使用以下SQL语句: DROP INDEX index_name; 其中index_name是要删除的索引的名...
    99+
    2024-05-14
    pgsql
  • db2表空间状态0x4000怎么解决
    表空间状态0x4000表示该表空间为“冻结”状态,这可能是由于一些异常情况导致的。要解决这个问题,可以尝试以下几种方法: ...
    99+
    2024-05-14
    db2
  • mysql大文本字段优化的方法是什么
    在MySQL中,大文本字段(如TEXT、BLOB类型)的优化方法有以下几种: 使用合适的数据类型:根据实际需求选择合适的数据类型...
    99+
    2024-05-14
    mysql
  • oracle更改字符集的方法是什么
    要更改Oracle数据库的字符集,可以通过以下步骤来实现: 确保在更改字符集之前备份数据库,以防发生意外情况。 确定当前数据...
    99+
    2024-05-14
    oracle
  • 怎么更改oracle数据库字符集
    要更改Oracle数据库的字符集,可以按照以下步骤操作: 确保备份数据:在进行字符集更改之前,务必备份数据库以防止数据丢失。 ...
    99+
    2024-05-14
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作