用vbs实现文本循环读取

2023-12-08 0 703

因为测试中需要读取一批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

好了到这里就完成了.

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 VBS 用vbs实现文本循环读取 https://www.u-9.cn/jiaoben/vbscript/130587.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务