当前位置: 首页 > 面试题库 >

selenium从xpath获取动态ID

咸晨
2023-03-14
问题内容

Selenium RC中是否有办法从xpath获取ID?

如果我有xpath

/html/body/div/div//input

我想获取与xpath相关的所有节点的ID


问题答案:

您可以通过运行javascript使用this.browserbot.findElement('/html/body/div/div//input')以下命令获得该代码:

当然,这取决于源语言,但这将是这样的(在perl中,未经测试):

#first count the number of inputs with ids
my $count = $selObj->get_xpath_count('/html/body/div/div//input[@id]');

#build a javascript that iterates through the inputs and saves their IDs
my $javascript;
$javascript .= 'var elements = [];';
$javascript .= "for (i=1;i<=$count;i++)";
$javascript .= "  elements.push(this.browserbot.findElement('/html/body/div/div/input['+i+']').id);";
#the last thing it should do is output a string, which Selenium will return to you
$javascript .= "elements.join(',');";

my $idString = $selObj->get_eval($javascript);

我一直认为应该有一个更直接的方法来执行此操作,但是我还没有找到它!

*根据注释进行 *编辑 ,for循环计数应从1开始并包含$count,而且findElement行在输入之前仅需要一个正斜杠。

EDIT2 根据进一步的评论添加一个完全不同的想法:

附加到每个页面上的Selenium javascript包括一个称为的函数eval_xpath,该函数返回给定查询的DOM元素数组。听起来像您想要的吗?

这就是我认为javascript的样子(再次未经测试):

var elements = eval_xpath('/html/body/div/div//input',this.browserbot.getCurrentWindow().document);
var results = [];
for (i=0;i<elements.length;i++){
  results.push(elements[i].id);
}

results.join(',');


 类似资料:
  • 问题内容: 我可以从org.w3c.dom.Node获取完整的xpath吗? 说当前节点指向xml文档中间的某个位置。我想提取该元素的xpath。 我正在寻找的输出xpath是。节点xpath的父级。只需忽略具有表达式并指向同一节点的xpath。 问题答案: 没有获取XPath的通用方法,主要是因为没有一个通用XPath可以标识文档中的特定节点。在某些架构中,节点将由属性唯一标识(并且可能是最常见

  • 我有一个ID列表,希望在XPath中动态传递这些ID。下面是我正在使用的代码: 尽管print(path)在执行此代码时给出了确切的路径。我得到以下错误: NoSuchElementException:消息:没有这样的元素:无法定位元素:{“方法”:“xpath”,“选择器”:“//tr[contains(@id,'tr_m_1570_1025516')]/td[2]/table/tbody/tr

  • 我搜索了几个问题,但没有找到我的问题: 我想测试/验证2个系统的配置页面。但我面临三个挑战: 1、两个系统的页面看起来完全相同,但实际上相同项目(文本、下拉列表、单选按钮等)的dom/xPath信息完全不同。例如,页面上2个系统的“设备名称”字段有2个不同的xPath,例如sys1的xPath为“//input/abc”,sys2的xPath为“//input/xyz”。 2.有时页面是动态生成的

  • 我正在尝试使用webdriver从上面的html代码中获取动态跨度文本,但得到的是: org.openqa.selenium.nosuchelementException:找不到元素:{“method”:“id”,“selector”:“MathQ2”} 我需要从span id“MathQ2”获取文本:“6+4=” 此文本“6+4=”在每次刷新页面或加载新页面时都在更改 我尝试过xpath、id、

  • 对于具有step层次结构(Region-Site-Zone-ZoneID)的复杂站点,我试图构建一个动态xpath来计算ZoneID(1..10) 代码 问题:如何按ByZoneName=By.xpath组合代码行(“//span[.='”+zonename+“']”);对于动态区域名id(对于相同的执行VAD1、VAD2、vad3...VAD10) 实际:此结构对zoneName=vad1正确执

  • 我正在开发一个条形码阅读器应用程序,我想在读取条形码时显示产品图像,所以我用产品条形码编号重命名了照片,并将其放入drawables文件夹。照片名称适用于ex 1234567,请尝试使用条形码编号检索。但我在条形码上出错了。我该怎么做?