google搜索 51Testing站内搜索                    软件测试门户 | 软件测试培 训 | 文章资料精选 | 软件测试论坛 | 软件测试博客 | 测试招聘求职 
打印

[求助] 关于datatable的列

关于datatable的列


在datatable中有两列A和B,都在同一sheet中,结构如下:
   A         B
1  some       may
2      thing          too
3        try          catch
4      excep      
5
想取得B列共有多少行,如何取?谢谢各位解达!

[ 本帖最后由 workstudy 于 2008-5-22 08:52 编辑 ]

TOP

最直接的办法自己写个方法,判断下.

TOP

那怎么写?QTP没有自带的函数吗?

TOP

顶起来!

TOP

The following example uses the GetParameterCount method to find the total number of parameters (columns) in the run-time Data Table sheet (MySheet) and writes it to the report.

paramcount = DataTable.GetSheet("MySheet").GetParameterCount

Reporter.ReportEvent 2, "There are " &paramcount, "columns in the data sheet."

TOP

此函数得出的是runtime-table 里有多少列,没有得出我想看其中某列有多少行的结果啊

TOP

rowcount = DataTable.GetSheet("MySheet").GetRowCount

TOP

看错了,还是自己写个好了

TOP

如果B的行数大于A,那直接datatable.GetSheet("Action1").GetRowCount就可以得出B的行数
如果B的行数小于A,那么:
Dim i ,Brow
Brow = 0
Arow= datatable.GetSheet("Action1").GetRowCount
For i = 1 to Arow
        datatable.GetSheet("Action1").SetCurrentRow(i)
        Bvalue = datatable.RawValue("B" , "Action1")

        If Bvalue <> "" Then
                Brow=Brow+1
                elseif Bvalue = "" then
                        reporter.ReportEvent micDone , "B行数" , Brow
                        Exit for
        End If
        datatable.GetSheet("Action1").SetNextRow
Next
向着QTP自动化方向深入发展
欢迎QTP研究者一起交流,相互进步
欢迎访问我的测试博客:http://www.51testing.com/?uid/161787

TOP

如果出现B行前两行有字符,第三行和第四行没有,而第五行又有字符,那就会漏掉啊!
要怎么判断呢?

TOP





LZ自己应该多想想,其实稍微改下就好了
Dim i ,Brow
Brow = 0
Arow= datatable.GetSheet("Action1").GetRowCount
For i = 1 to Arow
        datatable.GetSheet("Action1").SetCurrentRow(i)
        Bvalue = datatable.RawValue("B" , "Action1")

        If Bvalue <> "" Then
                Brow=Brow+1
                elseif Bvalue = "" then
                        'msgbox Brow
                        Brow=Brow
        End If
        datatable.GetSheet("Action1").SetNextRow
Next
reporter.ReportEvent micDone , "B行数" , Brow
向着QTP自动化方向深入发展
欢迎QTP研究者一起交流,相互进步
欢迎访问我的测试博客:http://www.51testing.com/?uid/161787

TOP

非常感谢zte_boy的回复!
我在想如何中间的两行空数据也是测试数据呢?再这样想的话就没完了
哈哈,有点叫劲了。。。
datatable.GetSheet("Action1").SetNextRow 这句好像多余了,呵呵

[ 本帖最后由 workstudy 于 2008-5-22 17:07 编辑 ]

TOP

中间两行是空行也没问题啊,这段代码也是可以实现的啊
向着QTP自动化方向深入发展
欢迎QTP研究者一起交流,相互进步
欢迎访问我的测试博客:http://www.51testing.com/?uid/161787

TOP

恩,代码我已经试过了。
我是说中间两行的空内容假如也是要计算在行数内的,这样的话就没法算了吧,呵呵,因为B列
没有A列长,B列少于A列的行数按我说的那样也会计算在内。说明这个“需求”是有问题的吧

TOP

'======================想读哪行就哪行,如果测出bug跟我留言
Dim i ,Brow
Brow = 0
Arow= datatable.GetSheet("Action1").GetRowCount
For i = 1 to Arow

        datatable.GetSheet("Action1").SetCurrentRow(i)
        Bvalue = datatable.RawValue("B" , "Action1")
      if Bvalue <>  "" and i<Arow then
                       ' msgbox "Brow:"&Brow&"ROW:"&Arow&"i:"&i
                        Brow=i
   Elseif Bvalue <>  "" and i=Arow then

                Brow=Arow
     End If
        datatable.GetSheet("Action1").SetNextRow
Next
msgbox  "B行数:" &Brow

TOP

 
当前时区 GMT+8, 现在时间是 2008-10-13 23:52Copyright(C)上海博为峰软件技术有限公司 2001-2007 电话:021-64471599-8017
当您在访问网站、论坛及博客过程中遇到问题时可发送email:webmaster@51testing.com或发送论坛短信至管理员风在吹