51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1510|回复: 3
打印 上一主题 下一主题

[原创] 调用action后,datatable的sheet名称变了

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2010-7-13 17:26:12 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
QTP中Action1调用了existing action2,查看action1的datatable是原来两个datatable的合集,但是action2中的sheet页的名字变了,所以action2相关的脚本就报错说找不到,应该怎么办呢
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2010-7-15 16:32:50 | 只看该作者
为什么你用两个action都用到datatable阿,改成一个就可以拉,还有你是用importsheet方法导入的么,导入的sheet名称对么,是不是用了dtlocal。。
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2010-7-16 12:33:10 | 只看该作者
有贴图吗?
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2010-7-16 17:26:54 | 只看该作者
Action被调用时,其对应的本地表名是会变的,例如调用TEST脚本中的Action1,那么被调用时对应的sheet名就会变成Action1[TEST]

解决办法:
在被调用脚本中使用本地表时,一律使用dtlocalsheet,不要用索引或具体表名称
如果无法直接使用dtlocalsheet的,如导入Excel时,先获取本地表名称
具体如下:
    sheetName=DataTable.GetSheet(dtlocalsheet).Name
   DataTable.ImportSheet "..\..\Data\"&"TEST"&".xls","test1",sheetName

[ 本帖最后由 souchy 于 2010-7-16 17:30 编辑 ]
回复 支持 反对

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-15 12:41 , Processed in 0.078465 second(s), 28 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表