51Testing丛书连载:(三十一)精通QTP——自动化测试技术领航

发表于:2012-1-17 10:40

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:余杰 赵旭斌    来源:51Testing软件测试网

分享:

  验证全部结束,一切都和叙述得完全一致!到此,相信读者都已经对QTP的Datatable有了更深刻的认知。

  细心的读者一定注意到了,好像这个小节中都在使用Global Sheet。所以,相信读者一定会有疑问“为什么不能用LocalSheet?”因为针对将不同脚本组合成一个业务脚本的这种形式,用Local Sheet是不能将值传递给另一个脚本的,只有Global Sheet才是被共享的!就算不是用组合脚本这种形式,把所有的业务写在一个脚本中,用Action划分,那为了共享不同Action间的数据,仍然要使用Global Sheet。

  至于如何把两个脚本嵌入到一个脚本中,这是后续章节的内容。

1.8.4  用好DataTable对象使脚本更加灵活

  因为QTP的DataTable是一个保留对象,所以,Mercury在实现此功能的时候为它写了很多的实用方法。使用好这些实用的方法,可以让我们的脚本更加灵活、多变。作者接下来列举一些常用的方法供读者参考:

  1.动态地在DataTable中添加新列并赋值

DataTable.GlobalSheet.AddParameter "Column1","Value1"

DataTable.GlobalSheet.AddParameter "Column2","Value2"

DataTable.LocalSheet.AddParameter "Column3","Value3"

  运行结果图1-219和图1-220所示。

图1-219

图1-220

  2.动态地在DataTable里增加新行并赋值

DataTable.GetSheet("Action1").SetCurrentRow ( 2  '1

DataTable.Value("Column4","Action1") = "Row2" 

'或者也可以是: 

DataTable.Value(1,2) =  "Row2"

  运行结果图1-221所示。

图1-221

  注:必须使用“句1”才能新增行,不然会被原值替代。因为QTP在GetCurrentRow这个过程结束后仍然处于第1行。

53/5<12345>
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号