用vbs實(shí)現(xiàn)文本循環(huán)讀取
因?yàn)闇y(cè)試中需要讀取一批URL數(shù)據(jù)進(jìn)行瀏覽,其實(shí)使用QTP本身的table能實(shí)現(xiàn)多種讀取方式,但是因?yàn)樾枰猼abel是使用excel保存的,在沒(méi)有安裝excel的機(jī)器或者vsita機(jī)器上運(yùn)行該部分腳本會(huì)遇到問(wèn)題,為了不必要的麻煩,因而使用txt保存網(wǎng)址數(shù)據(jù)。
但是vbs好像沒(méi)有提供設(shè)置文件讀取位置的函數(shù)(python提供),網(wǎng)上沒(méi)有找到這塊可用的代碼,可能大家基本沒(méi)有我這么低級(jí)的需求吧囧rz……,后來(lái)還是搞定了,所以將代碼貼出來(lái),以作備忘。其實(shí)核心就是發(fā)現(xiàn)讀取到文本的最后一行,那么重新打開(kāi)該文件即可。
代碼:
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
http://www.dbjr.com.cn
上面的代碼比較簡(jiǎn)單,而且只能獲取到第一行的數(shù)據(jù),推薦大家用下面的代碼實(shí)現(xiàn)配置文件讀取
以下是一個(gè)讀取配置文件的函數(shù):
本函數(shù)僅適用于以下格式的配置文件(.ini,.txt,.inf):
[Mark1]
key1=key1value
key2=key2value
........
[Mark2]
key1=key1value
key2=key2value
核心代碼
'************************************************************ '功能:讀取配置文件(.ini,.txt格式)的配置項(xiàng)的值,并返回值 '參數(shù):FilePath - 配置文件的完整路徑 ' Mark - 配置開(kāi)始標(biāo)記 ' Key - 需要獲取的配置項(xiàng)名稱 '調(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 '初始化配置標(biāo)記,默認(rèn)為未找到 Flag = 0 '打開(kāi)配置文件 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ù)行是否為需要查找的配置開(kāi)始標(biāo)記 If LCase(Trim(Str_ReadLine))="[" & Lcase(Mark) & "]" Then '找到配置開(kāi)始標(biāo)記 Flag = 1 '循環(huán)讀取當(dāng)前配置開(kāi)始標(biāo)記下的配置項(xiàng),直到在當(dāng)前配置標(biāo)記下找到所需配置項(xiàng) '或下一個(gè)配置項(xiàng)開(kāi)始標(biāo)記出現(xiàn)時(shí)退出 Do Str_ReadLine = ConfigFile.ReadLine retNum = InStr(Str_ReadLine,"=") '檢查讀取的配置項(xiàng)是否有等號(hào) If retNum > 0 Then '判斷獲取配置項(xiàng)名稱是否為所需的配置項(xiàng) If Trim(LCase(Left(Str_ReadLine,retNum-1)))= Trim(LCase(Key)) Then '獲取配置項(xiàng)等號(hào)后的數(shù)據(jù) GetConfig = Trim(Right(Str_ReadLine,Len(Str_ReadLine)-retNum)) '找到后,退出函數(shù) Exit Function End If End If '判斷當(dāng)前是否為下一個(gè)配置項(xiàng)開(kāi)始標(biāo)記 If (InStr(Str_ReadLine,"[")>0 And InStr(Str_ReadLine,"]")>0) Then '標(biāo)記當(dāng)前配置項(xiàng)開(kāi)始標(biāo)記為下一個(gè)配置 Flag = 0 '退出函數(shù) Exit Function End If Loop Until (Flag = 0 Or ConfigFile.AtEndOfStream) End If End If Loop Until ConfigFile.AtEndOfStream '關(guān)閉文件 ConfigFile.Close Set fso = Nothing Else '文件未找到,給出提示信息 MsgBox "配置文件"&"[" & FilePath &"]不存在,請(qǐng)檢查路徑是否正確." End If End Function
實(shí)例:
我們需要讀取d:\config\environment.ini文件的[Computer2]下的IP項(xiàng)的值,文件內(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
好了到這里就完成了.
相關(guān)文章
VBS 提取狗狗影視中的ED2K連接的實(shí)現(xiàn)代碼
這篇文章主要介紹了通過(guò)VBS 提取狗狗影視中的ED2K連接,需要的朋友可以參考下2013-07-07TXT轉(zhuǎn)HTM、HTML「TXT轉(zhuǎn)網(wǎng)頁(yè)」的vbs實(shí)現(xiàn)代碼
試用過(guò)的Visual CHM,Power CHM,Easy CHM也非常令人失望??磥?lái)還是自給自足吧。本文介紹的方法不一定適用于所有用戶,看不懂的同學(xué)一律不要提問(wèn)和請(qǐng)教2011-11-11VBS教程:正則表達(dá)式簡(jiǎn)介 -正則表達(dá)式
VBS教程:正則表達(dá)式簡(jiǎn)介 -正則表達(dá)式...2006-11-11VBS基礎(chǔ)篇 - vbscript TextStream對(duì)象
TextStream對(duì)象是用于訪問(wèn)文本文件的對(duì)象,它是FileSystemObject一個(gè)獨(dú)立的附屬對(duì)象,但在使用TextStream對(duì)象時(shí),我們?nèi)砸柚鶩ileSystemObject 對(duì)象或其附屬對(duì)象來(lái)創(chuàng)建一個(gè) TextStream 對(duì)象并訪問(wèn)磁盤文件的內(nèi)容,需要的朋友可以參考下2018-06-06vbs實(shí)現(xiàn)的漢字轉(zhuǎn)拼音的函數(shù)
網(wǎng)上都是js轉(zhuǎn)為拼音的,這才我們看vbs版的漢字轉(zhuǎn)拼音的代碼2008-06-06