用vbs實現(xiàn)文本循環(huán)讀取
因為測試中需要讀取一批URL數(shù)據(jù)進行瀏覽,其實使用QTP本身的table能實現(xiàn)多種讀取方式,但是因為需要tabel是使用excel保存的,在沒有安裝excel的機器或者vsita機器上運行該部分腳本會遇到問題,為了不必要的麻煩,因而使用txt保存網(wǎng)址數(shù)據(jù)。
但是vbs好像沒有提供設置文件讀取位置的函數(shù)(python提供),網(wǎng)上沒有找到這塊可用的代碼,可能大家基本沒有我這么低級的需求吧囧rz……,后來還是搞定了,所以將代碼貼出來,以作備忘。其實核心就是發(fā)現(xiàn)讀取到文本的最后一行,那么重新打開該文件即可。
代碼:
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
上面的代碼比較簡單,而且只能獲取到第一行的數(shù)據(jù),推薦大家用下面的代碼實現(xiàn)配置文件讀取
以下是一個讀取配置文件的函數(shù):
本函數(shù)僅適用于以下格式的配置文件(.ini,.txt,.inf):
[Mark1]
key1=key1value
key2=key2value
........
[Mark2]
key1=key1value
key2=key2value
核心代碼
'************************************************************
'功能:讀取配置文件(.ini,.txt格式)的配置項的值,并返回值
'參數(shù):FilePath - 配置文件的完整路徑
' Mark - 配置開始標記
' Key - 需要獲取的配置項名稱
'調(diào)用方法: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)
'循環(huán)讀取文件數(shù)據(jù)行
Do
Str_ReadLine = ConfigFile.ReadLine
WScript.Echo Str_ReadLine
'判斷讀取的數(shù)據(jù)行是否為空
If Str_ReadLine <> "" Then
'判斷讀取數(shù)據(jù)行是否為需要查找的配置開始標記
If LCase(Trim(Str_ReadLine))="[" & Lcase(Mark) & "]" Then
'找到配置開始標記
Flag = 1
'循環(huán)讀取當前配置開始標記下的配置項,直到在當前配置標記下找到所需配置項
'或下一個配置項開始標記出現(xiàn)時退出
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
'獲取配置項等號后的數(shù)據(jù)
GetConfig = Trim(Right(Str_ReadLine,Len(Str_ReadLine)-retNum))
'找到后,退出函數(shù)
Exit Function
End If
End If
'判斷當前是否為下一個配置項開始標記
If (InStr(Str_ReadLine,"[")>0 And InStr(Str_ReadLine,"]")>0) Then
'標記當前配置項開始標記為下一個配置
Flag = 0
'退出函數(shù)
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項的值,文件內(nèi)容如下:
[Computer1]
ComputerName=Computer1
IP=192.168.1.1
[Computer2]
ComputerName=Computer2
IP=192.168.1.2
使用以上函數(shù)即可獲取
IP = GetConfig("d:\config\environment.ini","Computer2","IP")
Msgbox IP
好了到這里就完成了.
版權(quán)聲明:本站文章來源標注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學習參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。
關注官方微信