用vbs实现文本循环读取
因为测试中需要读取一批URL数据进行浏览,其实使用QTP本身的table能实现多种读取方式,但是因为需要tabel是使用excel保存的,在没有安装excel的机器或者vsita机器上运行该部分脚本会遇到问题,为了不必要的麻烦,因而使用txt保存网址数据。
但是vbs好像没有提供设置文件读取位置的函数(python提供),网上没有找到这块可用的代码,可能大家基本没有我这么低级的需求吧囧rz……,后来还是搞定了,所以将代码贴出来,以作备忘。其实核心就是发现读取到文本的最后一行,那么重新打开该文件即可。
代码:
msgbox(GetIni("d://vbscript//config.txt")) Function GetIni(strIniFilePath ) Const ForReading = 1 Const TriStateTrue = -2 Dim myFso Dim MyFile Set myFso = CreateObject("Scripting.FileSystemObject") Set MyFile = myFso.OpenTextFile(strIniFilePath,ForReading,False,TriStateTrue) GetIni = MyFile.ReadLine() If MyFile.AtEndOfStream=True Then Set MyFile = Nothing Set MyFile = myFso.OpenTextFile(strIniFilePath,ForReading,False,TriStateTrue) End If MyFile.Close Set MyFile = Nothing Set myFso = Nothing End Function
config.txt
https://www.jb51.net
上面的代码比较简单,而且只能获取到第一行的数据,推荐大家用下面的代码实现配置文件读取
以下是一个读取配置文件的函数:
本函数仅适用于以下格式的配置文件(.ini,.txt,.inf):
[Mark1]
key1=key1value
key2=key2value
........
[Mark2]
key1=key1value
key2=key2value
核心代码
'************************************************************ '功能:读取配置文件(.ini,.txt格式)的配置项的值,并返回值 '参数:FilePath - 配置文件的完整路径 ' Mark - 配置开始标记 ' Key - 需要获取的配置项名称 '调用方法:Ret = GetConfig("d:\configure.ini","Computer","IP") '作者:虎肖至尊 '日期:2013-06-20 '************************************************************ Function GetConfig(FilePath,Mark,Key) Dim fso, Str_ReadLine Set fso = CreateObject("Scripting.FileSystemObject") '判断配置文件是否存在 If fso.FileExists(FilePath) Then '初始化配置标记,默认为未找到 Flag = 0 '打开配置文件 Set ConfigFile = fso.opentextfile(FilePath, 1) '循环读取文件数据行 Do Str_ReadLine = ConfigFile.ReadLine WScript.Echo Str_ReadLine '判断读取的数据行是否为空 If Str_ReadLine <> "" Then '判断读取数据行是否为需要查找的配置开始标记 If LCase(Trim(Str_ReadLine))="[" & Lcase(Mark) & "]" Then '找到配置开始标记 Flag = 1 '循环读取当前配置开始标记下的配置项,直到在当前配置标记下找到所需配置项 '或下一个配置项开始标记出现时退出 Do Str_ReadLine = ConfigFile.ReadLine retNum = InStr(Str_ReadLine,"=") '检查读取的配置项是否有等号 If retNum > 0 Then '判断获取配置项名称是否为所需的配置项 If Trim(LCase(Left(Str_ReadLine,retNum-1)))= Trim(LCase(Key)) Then '获取配置项等号后的数据 GetConfig = Trim(Right(Str_ReadLine,Len(Str_ReadLine)-retNum)) '找到后,退出函数 Exit Function End If End If '判断当前是否为下一个配置项开始标记 If (InStr(Str_ReadLine,"[")>0 And InStr(Str_ReadLine,"]")>0) Then '标记当前配置项开始标记为下一个配置 Flag = 0 '退出函数 Exit Function End If Loop Until (Flag = 0 Or ConfigFile.AtEndOfStream) End If End If Loop Until ConfigFile.AtEndOfStream '关闭文件 ConfigFile.Close Set fso = Nothing Else '文件未找到,给出提示信息 MsgBox "配置文件"&"[" & FilePath &"]不存在,请检查路径是否正确." End If End Function
实例:
我们需要读取d:\config\environment.ini文件的[Computer2]下的IP项的值,文件内容如下:
[Computer1]
ComputerName=Computer1
IP=192.168.1.1
[Computer2]
ComputerName=Computer2
IP=192.168.1.2
使用以上函数即可获取
IP = GetConfig("d:\config\environment.ini","Computer2","IP")
Msgbox IP
好了到这里就完成了.
上一篇:没有了
栏 目:vb
下一篇:拖拽文件显示文件路径的vbs代码
本文标题:用vbs实现文本循环读取
本文地址:https://www.xiuzhanwang.com/a1/vb/7081.html
您可能感兴趣的文章
- 01-10下载文件到本地运行的vbs
- 01-10VBS中的正则表达式的用法大全 <font color=red>原创&
- 01-10VBS中SendKeys的基本应用
- 01-10VBScript教程 第十一课深入VBScript
- 01-10用VBSCRIPT控制ONSUBMIT事件
- 01-10VBScript语法速查及实例说明
- 01-10VBS中Select CASE的其它用法
- 01-10VBScript教程 第七课使用条件语句
- 01-10vbscript 可以按引用传递参数吗?
- 01-10VBScript教程 第二课在HTML页面中添加VBscript代码
阅读排行
本栏相关
- 01-10下载文件到本地运行的vbs
- 01-10飘叶千夫指源代码,又称qq刷屏器
- 01-10SendKeys参考文档
- 01-10什么是一个高效的软件
- 01-10VBS中的正则表达式的用法大全 &l
- 01-10exe2swf 工具(Adodb.Stream版)
- 01-10VBS中SendKeys的基本应用
- 01-10用VBSCRIPT控制ONSUBMIT事件
- 01-10VBScript教程 第十一课深入VBScript
- 01-10VBScript语法速查及实例说明
随机阅读
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文
- 01-10delphi制作wav文件的方法
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 01-11ajax实现页面的局部加载
- 04-02jquery与jsp,用jquery
- 01-10SublimeText编译C开发环境设置
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-10C#中split用法实例总结