yuandjing 发表于 2008-1-28 11:49:58

告别QTP板块,临走吐点心血送给大家(知识是共享和堆积的,不是卖钱的,完全免费)

我07年的帖子,现在还有那么多网友支持真是激动不已,现在我又回来做QTP了,也积累了更多更新的经验工作总结 - 请上E测中国站点我的博客,我在那边的用户名为wally,愿与大家一起学习进步!

大家好,由于换了新的工作环境,这里不再使用QTP了,所以我可能几年不上QTP这个板块了
临走吐点vbs脚本出来送给大家,大家可以加到qtp的resource里去,就可以直接调用了,也欢迎大家以后加函数进去
(外部链接milo.jiang兄的数据库操作:http://bbs.51testing.com/viewthread.php?tid=118028&highlight=)
另外申明一下:
1.有部分函数改写了 风过无息 的blog的函数
2.有部分函数多余了,比如对于日期处理的函数vb本来就有自己的函数,大家可以用vb的函数
3.但是有部分vbs的函数不太好,被我改写了,比如vb的随机函数,发现使用起来相当不随机,我改写了这个函数,现在随机多了
4.附件的rar文件里有个excel的文件,包含了多这些函数的输入参数和输出参数的定义

希望大家多多交流,扩充这个底层脚本。也可以联系我提意见
这个板块成就了如今的我,所以我把我的这些脚本贡献出来,希望能让更多的人受益 Sharing will get in more
谢谢各位

(共42个函数,这里举隅一二,详细请见rar附件)
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
'''''上海(保密一下)软件有限公司开发部''''''''''''''''''''''''''''''''''''
'''''函数功能:Quick 和 Robot 常用库函数'''''''''''''''''''''''''''''
'''''说明:1.以QTP_开头的函数只适用于QuickTest'''''''''''''''''''''''
'''''      2.以Robot_开头的函数只适用于Robot'''''''''''''''''''''''''
'''''      3.除以上外,QuickTest和Robot都适用''''''''''''''''''''''''
'''''作者:俞戴龙''''''''''''''''''''''''''''''''''''''''''''''''''''
'''''开始编撰日期:2007-8-17'''''''''''''''''''''''''''''''''''''''''
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''

'Option Explicit

''''''''''''''''''''''''''''''''''''''''''''''''
'''测试用调用函数'''''''''''''''''''''''''''''''



''''''''''''''''''''''''''''''''''''''''''''''''
''''''''''''''''''''''''''''''''''''''''''''''''

'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
'''以下为QuickTest和Robot都适用函数''''''''''''''''''''''''''''''''''
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
'随机函数生成
'输入值:生成值范围 i~j
'返回值:随机数
Public Function Get_RandNum(fromNum,toNum)
      If (fromNum<0) Or (toNum<0) Then
                MsgBox "只接受大于零的输入"
      ElseIf fromNum>toNum then
                MsgBox "起始值必须小于结束值"
      Else
                Dim RunTime
                Randomize   
                RunTime = Int((10 * Rnd) + 1)
                Dim MyValue,i
                For i = 1 To RunTime
                        Randomize
                        MyValue = Int(((toNum - fromNum + 1) * Rnd) + (fromNum))
                Next
         Get_randNum=MyValue
          End If
End Function

'去掉字符串中的重复项
Function NoRepeat(Inp,Sp)
Dim aa,flag,words,length,i,j,k,sp1,sp2,cc
      aa = Inp
      Do
                flag = False
                words = Split(aa,Sp)
                length = UBound(words)
                For i = 0 To (length -1)
                        sp1 = words(i)
                        For j = (i+1) To length
                              sp2 = words(j)
                              If sp1 = sp2 Then
                                        flag = True
                                        aa = ""
                                        For k = 0 To (j-1)
                                                aa = aa & words(k) & sp
                                        Next
                                        For k = (j + 1) To length
                                                aa = aa & words(k) & sp
                                        Next
                                       
                                        cc = Len(aa)
                                        aa = Left(aa,(cc - 1))
                              End If
                        Next
                        If flag = True Then
                              Exit For
                        End if
                Next
      Loop Until flag = false
      NoRepeat = aa
End Function

'按ASCII码值冒泡排序
Function BubbleSort(VString,Spl,Func)
      Dim Str,StrLength,i,j
      Str = Split(VString,Spl)
      StrLength = UBound(Str) + 1
      For i = 1 To (StrLength-1)
                For j = (i+1) To StrLength
                        If Func = 1 then
                              If Asc(Str(i-1)) < Asc(Str(j-1)) Then
                                        Call Swap(Str(i-1),Str(j-1))
                              End If
                        Else
                              If Asc(Str(i-1)) > Asc(Str(j-1)) Then
                                        Call Swap(Str(i-1),Str(j-1))
                              End If
                        End If
                Next
      Next
      j = ""
      For i = 1 To StrLength
                j = j & Str(i-1) & Spl
      Next
      j = Left(j,(StrLength * 2 -1))
      BubbleSort = j
End Function


'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
'''以下为仅QuickTest适用函数'''''''''''''''''''''''''''''''''''''''''
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''

'让QTP运行时保持最小化
Public Sub QTP_Small()
      Dim objQTPWin
      Set objQTPWin = GetObject("" , "QuickTest.Application")
      objQTPWin.WindowState = "Minimized"
      Set objQTPWin = Nothing
End Sub

'恢复QTP窗口
Public Sub QTP_Big()
      Dim objQTPWin
      Set objQTPWin = GetObject("" , "QuickTest.Application")
      objQTPWin.WindowState = "Restored"
      Set objQTPWin = Nothing
End Sub

'定时停留弹出框函数
Sub QTP_Msgbox(Value,waitTime,Title)
      Dim WshShell
    Set WshShell = CreateObject("WScript.Shell")
    WshShell.Popup Value, waitTime, Title
    Set WshShell = nothing
End Sub

'改变Excel的单元格颜色
Public Function QTP_Change_Color(pathway,sheetname,x,y,color)
      Dim srcData,srcDoc,sp1,sp2,num,use,a1,a2,a3
      set srcData = CreateObject("Excel.Application")
      srcData.Visible = True
      set srcDoc = srcData.Workbooks.Open(pathway)
      srcDoc.Worksheets(sheetname).Activate
      If color = "red" Then
                srcDoc.Worksheets(sheetname).Cells(x,y).Interior.color=vbred
      ElseIf color = "green" Then
                srcDoc.Worksheets(sheetname).Cells(x,y).Interior.color=vbgreen
      Else
                MsgBox "输入的颜色参数不正确,只接收""red""和""green"""
      End If

      Dim WshShell
      Set WshShell=CreateObject("Wscript.Shell")
      WshShell.SendKeys "^s"
      wait(1)
      
      srcData.Workbooks.Close
      Set srcDoc = nothing
      Window("text:=Microsoft Excel").Close
End Function

'写Excel文件元素并保存退出
Public Function QTP_Write_Excel(pathway,sheetname,x,y,content)
      Dim srcData,srcDoc,sp1,sp2,num,use,a1,a2,a3
      set srcData = CreateObject("Excel.Application")
      srcData.Visible = True
      set srcDoc = srcData.Workbooks.Open(pathway)
      srcDoc.Worksheets(sheetname).Activate
      srcDoc.Worksheets(sheetname).Cells(x,y).value = content

      Dim WshShell
      Set WshShell=CreateObject("Wscript.Shell")
      WshShell.SendKeys "^s"
      wait(1)
      
      srcData.Workbooks.Close
      Set srcDoc = nothing
      
      Window("text:=Microsoft Excel").Close
End Function

[ 本帖最后由 yuandjing 于 2009-11-5 18:03 编辑 ]

yuandjing 发表于 2008-1-28 11:52:49

本帖最后由 yuandjing 于 2011-10-17 11:15 编辑

发现在这个网页上显示的不怎么规整,大家可以用这个板块的一个工具“vbsedt33”来查看和编辑脚本
从来没坐过沙发,今天顺便享受一下先


欢迎关注我的新浪微博:http://weibo.com/quicktest

51mobile 发表于 2008-1-28 12:50:31

:lol 非常不错,:victory:

lantianwei 发表于 2008-1-28 13:43:17

感谢LZ的无私奉献!:)

nestanesta 发表于 2008-1-28 14:01:16

经典的东西,顶你

ppent 发表于 2008-1-28 14:40:10

谢谢 以后常回家看看

threeg 发表于 2008-1-28 15:21:27

LZ好人啊,

frankwangzy1103 发表于 2008-1-28 15:22:10

谢谢,论坛就需要多一点你这样的人

wzdoxu 发表于 2008-1-28 15:28:36

谢谢楼主分享这么好的东东!

yuandjing 发表于 2008-1-28 15:37:53

原帖由 frankwangzy1103 于 2008-1-28 15:22 发表 http://bbs.51testing.com/images/common/back.gif
谢谢,论坛就需要多一点你这样的人
呵呵,多些夸奖,常看国外的论坛发现国内的人老喜欢吧自己的心包起来,这就像手帕包BT一样,最终只能越包越小
分享很重要,分享的越多学习到的也越多
一个苹果换一个苹果,每个人只有一个苹果
一份知识换一份知识,每个人将有两份知识
加油,同志们,51testing是个测试人才汇集的地方,我们国家的软件行业不能落后!

waiverson 发表于 2008-1-28 16:04:24

非常感谢~ 搂主的一手资料相信能让更多人对QTP的实际应用更上一层楼

今天有雾 发表于 2008-1-28 16:49:47

感谢楼主,希望楼主还是能经常回来看看好了

xiaoyaoke 发表于 2008-1-28 16:54:27

楼主的资料真的很不多,希望楼主可以在新的领域一帆风顺,然后和大家分享经验
感谢楼主的无私奉献

yanzs0120 发表于 2008-1-28 17:17:17

真是谢谢啦。正在学习中~~~~~~~~~~

jxt 发表于 2008-1-29 11:53:31

谢谢!

you力 发表于 2008-1-29 11:58:29

这样的好贴越来越少了

thloong 发表于 2008-1-29 12:16:09

这样的好人真是不多,LZ常回来看看啊

coomon2001 发表于 2008-1-29 12:29:27

多谢楼主,受益匪浅啊

wuyu702 发表于 2008-1-29 14:15:00

谢谢 楼主无私奉献..hoho

language_fw 发表于 2008-1-29 14:18:32

多谢楼主,虽然我关注QTP的时间不是太长,但是你的第一手资料确实让我受益匪浅。祝你在以后工作的道路上越走越顺。
页: [1] 2 3 4 5 6 7 8 9 10
查看完整版本: 告别QTP板块,临走吐点心血送给大家(知识是共享和堆积的,不是卖钱的,完全免费)