验证全部结束,一切都和叙述得完全一致!到此,相信读者都已经对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行。