用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.lingkb.com

    上面的代码比较简单,而且只能获取到第一行的数据,推荐大家用下面的代码实现配置文件读取

    以下是一个读取配置文件的函数:
    本函数仅适用于以下格式的配置文件(.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

    好了到这里就完成了.