51Testing软件测试论坛

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

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 2386|回复: 4
打印 上一主题 下一主题

如何自动获取WEB上的所有元素

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2012-5-4 14:25:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
准备要用SELENIUM做自动化测试,大概有30来个页面,每个页面有20-50个元素(文本框,按钮等).
如果手动来列出相关的test,id,name,xpath,工作量太大。以后变化了又得重来一次。
所以想自动自动获取WEB上的所有元素,然后写到一个txt/excel中,比如登陆框用户名为:
excel 第一行为:text id name xpath
第二行为:用户名 3 user a/b/c
没有的id/name就为空。
不知有没有前辈做过此项工作,指点一二。
是否有现成的工具?
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2012-5-9 23:45:06 | 只看该作者
这是什么需求啊....不太明白目的...
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2012-5-30 14:40:34 | 只看该作者
刚想到的方法, 利用xpath去匹配.
先分析出当前需要的element 特征, 然后枚举即可.

举例:

for ele in driver.find_elements_by_xpath('//div/*'):
    print ele.location, ele.text
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2012-5-30 16:01:07 | 只看该作者
测试页面百度,输出该页所有ID 元素
require 'watir'
ie=Watir::IE.new
ie.goto 'www.baidu.com'
ie.divs.each {|div| puts div.id}
回复 支持 反对

使用道具 举报

该用户从未签到

5#
发表于 2012-5-30 17:17:41 | 只看该作者
Selenium
require 'rubygems'
require 'selenium-webdriver'
driver = Selenium::WebDriver.for :ie
driver.get("http://www.baidu.com/")
driver.find_elements(:xpath,"//div").each{|div| p div.as_json}
取出GUID
回复 支持 反对

使用道具 举报

本版积分规则

关闭

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

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

GMT+8, 2024-9-25 21:28 , Processed in 0.085281 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

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