工作中总会碰到一些难题,昨天又碰到一个:要通过循环遍历标签的子节点
找了不少人帮忙,感谢他们的悉心指导,然后自己也查了不少资料,终于解决了,总结下过程:
1、通过DOM定位元素:这样可以获取当前标签子节点的个数
后来想获取它的子集,怎么都不成功。无意中看到RF可以执行js,于是想通过js去获取,接着找资料,发现有方法去获取,于是照着写了一个js文件:
window.onload = function () { var nodelist = document.getElementsByClassName("thead-right")[0].getElementsByTagName("tr")[0]; var arr = nodelist.childNodes;return arr;
}
然后在RF中执行这个文件:
然后是一片狂错,原因是大括号的问题,最后一半括号要贴着最后一个分号,哎。。。。。
再执行,没有取到值,群里面提问,把function定义给去掉,直接贴脚本,于是成这样的了:
var nodelist = document.getElementsByClassName("thead-right")[0].getElementsByTagName("tr")[0]; var arr = nodelist.childNodes;return arr;再执行,'苍天有眼啊!!',终于出来了:[<selenium.webdriver.remote.webelement.WebElement object at 0x035817B0>,....]
这个是什么东西,完全看不明白啊!!!!
但至少我知道这是个列表,我便想去解析它们,这样尝试一下:${Nlist[1].text},你猜是什么结果?----"名称",这不是出来了吗?!!!!!
赶紧写个函数去解析每个列表成员:
def get_items_from_list(self, list):
listvalues = []
for item in list:
listvalues.append(item.text)
return listvalues
然后这样一调用,我的问题解决啦:
输出结果: