用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

好了到这里就完成了.

(0)

相关推荐

  • 用vbs实现文本循环读取

    因为测试中需要读取一批URL数据进行浏览,其实使用QTP本身的table能实现多种读取方式,但是因为需要tabel是使用excel保存的,在没有安装excel的机器或者vsita机器上运行该部分脚本会遇到问题,为了不必要的麻烦,因而使用txt保存网址数据. 但是vbs好像没有提供设置文件读取位置的函数(python提供),网上没有找到这块可用的代码,可能大家基本没有我这么低级的需求吧囧rz--,后来还是搞定了,所以将代码贴出来,以作备忘.其实核心就是发现读取到文本的最后一行,那么重新打开该文件即

  • 利用Shell脚本循环读取文件中每一行的方法详解

    前言 本文主要给大家介绍了关于使用Shell脚本循环读取文件每一行的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 一.使用for循环 for line in `cat filename` do echo $line done 或者 for line in $(cat filename) do echo $line done 二.使用while循环 while read -r line do echo $line done < filename While循环中rea

  • JS实用的带停顿的逐行文本循环滚动效果实例

    如下所示: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>JS实用的带停顿的逐行文本循环

  • ThinkPHP实现二级循环读取的方法

    本文实例讲述了ThinkPHP实现二级循环读取的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: $Category = D('Category')->where('category_pid=0')->findAll(); //dump($Category);  if(!empty($Category)){ //判断一级是否为空 foreach($Category as $key=>$value){   //循环读取 $pid =  $value['category_

  • C#使用FileStream循环读取大文件数据的方法示例

    本文实例讲述了C#使用FileStream循环读取大文件数据的方法.分享给大家供大家参考,具体如下: 今天学习了FileStream的用法,用来读取文件流,教程上都是读取小文件,一次性读取,但是如果遇到大文件,那么我们就需要循环读取文件. 直接上代码. 引用命名空间 using System.IO; 下面就是循环读取大文件的代码 class Program { static void Main(string[] args) { //循环读取大文本文件 FileStream fsRead; //获

  • python 循环读取txt文档 并转换成csv的方法

    如下所示: # -*- coding: utf-8 -*- """ Created on Fri Jul 29 15:49:06 2016 @author: user """ import os #从文件中读取某一行 linecache.checkcache可以刷新cache ,linecache可以缓存某一行的信息 import linecache def GetFileNameAndExt(filename): (filepath,tempf

  • python numpy实现多次循环读取文件 等间隔过滤数据示例

    numpy的np.fromfile会出现如下的问题,只能一次性读取文件的内容,不能追加读取,连续两次的np.fromfile读到的东西一样 如果数据文件太大(几个G或以上)不能一次性全读进去,需要追加读取 而我希望读到的donser1和donser2是连续的两段 (实际使用时,比如说读取的文件是二进制数据文件,每一块文件都包括包头+数据,希望将这两块分开获取,然后再做进一步处理) 代码: import numpy as np length=2500 plt_arr=np.linspace(0.0

  • python3 循环读取excel文件并写入json操作

    文件内容: excel内容: 代码: import xlrd import json import operator def read_xlsx(filename): # 打开excel文件 data1 = xlrd.open_workbook(filename) # 读取第一个工作表 table = data1.sheets()[0] # 统计行数 n_rows = table.nrows data = [] # 微信文章属性:wechat_name wechat_id title abstr

  • Mysql 存储过程中使用游标循环读取临时表

    游标 游标(Cursor)是用于查看或者处理结果集中的数据的一种方法.游标提供了在结果集中一次一行或者多行前进或向后浏览数据的能力. 游标的使用方式 定义游标:Declare 游标名称 CURSOR for table;(table也可以是select出来的结果集) 打开游标:Open 游标名称; 从结果集获取数据到变量:fetch 游标名称 into field1,field2; 执行语句:执行需要处理数据的语句 关闭游标:Close 游标名称; BEGIN # 声明自定义变量 declare

  • R语言-如何循环读取excel并保存为RData

    之前写过一个循环读取excel的代码,最近又有了新的需求:循环读取xlsx文件中的多个sheet,处理完之后循环输出到xlsx文件中的多个sheet中,总结一下. 1.循环读取csv文件并输出为RData格式 homedir <- "D:/Documents/tina/Database" #设置路径 setwd(homedir) temp = list.files(pattern="*.csv") for (i in 1:length(temp)) { fil

随机推荐