经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » ASP/ADO/VBScript » 查看文章
用vbs实现文本循环读取
来源:jb51  时间:2019/10/23 8:36:06  对本文有异议

因为测试中需要读取一批URL数据进行浏览,其实使用QTP本身的table能实现多种读取方式,但是因为需要tabel是使用excel保存的,在没有安装excel的机器或者vsita机器上运行该部分脚本会遇到问题,为了不必要的麻烦,因而使用txt保存网址数据。

但是vbs好像没有提供设置文件读取位置的函数(python提供),网上没有找到这块可用的代码,可能大家基本没有我这么低级的需求吧囧rz……,后来还是搞定了,所以将代码贴出来,以作备忘。其实核心就是发现读取到文本的最后一行,那么重新打开该文件即可。

代码:

  1. msgbox(GetIni("d://vbscript//config.txt"))
  2. Function GetIni(strIniFilePath )
  3. Const ForReading = 1
  4. Const TriStateTrue = -2
  5. Dim myFso
  6. Dim MyFile
  7. Set myFso = CreateObject("Scripting.FileSystemObject")
  8. Set MyFile = myFso.OpenTextFile(strIniFilePath,ForReading,False,TriStateTrue)
  9. GetIni = MyFile.ReadLine()
  10. If MyFile.AtEndOfStream=True Then
  11. Set MyFile = Nothing
  12. Set MyFile = myFso.OpenTextFile(strIniFilePath,ForReading,False,TriStateTrue)
  13. End If
  14. MyFile.Close
  15. Set MyFile = Nothing
  16. Set myFso = Nothing
  17. End Function

config.txt

https://www.jb51.net

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

以下是一个读取配置文件的函数:
本函数仅适用于以下格式的配置文件(.ini,.txt,.inf):

[Mark1]
key1=key1value
key2=key2value
........
[Mark2]
key1=key1value
key2=key2value

核心代码

  1. '************************************************************
  2. '功能:读取配置文件(.ini,.txt格式)的配置项的值,并返回值
  3. '参数:FilePath - 配置文件的完整路径
  4. ' Mark - 配置开始标记
  5. ' Key - 需要获取的配置项名称
  6. '调用方法:Ret = GetConfig("d:\configure.ini","Computer","IP")
  7. '作者:虎肖至尊
  8. '日期:2013-06-20
  9. '************************************************************
  10. Function GetConfig(FilePath,Mark,Key)
  11. Dim fso, Str_ReadLine
  12. Set fso = CreateObject("Scripting.FileSystemObject")
  13. '判断配置文件是否存在
  14. If fso.FileExists(FilePath) Then
  15. '初始化配置标记,默认为未找到
  16. Flag = 0
  17. '打开配置文件
  18. Set ConfigFile = fso.opentextfile(FilePath, 1)
  19. '循环读取文件数据行
  20. Do
  21. Str_ReadLine = ConfigFile.ReadLine
  22. WScript.Echo Str_ReadLine
  23. '判断读取的数据行是否为空
  24. If Str_ReadLine <> "" Then
  25. '判断读取数据行是否为需要查找的配置开始标记
  26. If LCase(Trim(Str_ReadLine))="[" & Lcase(Mark) & "]" Then
  27. '找到配置开始标记
  28. Flag = 1
  29. '循环读取当前配置开始标记下的配置项,直到在当前配置标记下找到所需配置项
  30. '或下一个配置项开始标记出现时退出
  31. Do
  32. Str_ReadLine = ConfigFile.ReadLine
  33. retNum = InStr(Str_ReadLine,"=")
  34. '检查读取的配置项是否有等号
  35. If retNum > 0 Then
  36. '判断获取配置项名称是否为所需的配置项
  37. If Trim(LCase(Left(Str_ReadLine,retNum-1)))= Trim(LCase(Key)) Then
  38. '获取配置项等号后的数据
  39. GetConfig = Trim(Right(Str_ReadLine,Len(Str_ReadLine)-retNum))
  40. '找到后,退出函数
  41. Exit Function
  42. End If
  43. End If
  44. '判断当前是否为下一个配置项开始标记
  45. If (InStr(Str_ReadLine,"[")>0 And InStr(Str_ReadLine,"]")>0) Then
  46. '标记当前配置项开始标记为下一个配置
  47. Flag = 0
  48. '退出函数
  49. Exit Function
  50. End If
  51. Loop Until (Flag = 0 Or ConfigFile.AtEndOfStream)
  52. End If
  53. End If
  54. Loop Until ConfigFile.AtEndOfStream
  55. '关闭文件
  56. ConfigFile.Close
  57. Set fso = Nothing
  58. Else
  59. '文件未找到,给出提示信息
  60. MsgBox "配置文件"&"[" & FilePath &"]不存在,请检查路径是否正确."
  61. End If
  62. 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

好了到这里就完成了.

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号