如何使用XPath和Selenium WebDriver通过Java单击SVG元素

时间:2017-01-24 13:05:16

标签: selenium svg xpath selenium-webdriver amcharts

我有一个带有几个矩形元素的SVG对象。使用geckodriver,我试图点击其中一个主SVG对象。但是使用xpath-checker时,我无法检测到相同的xpath

直到现在,我可以通过xpath向下钻取:

id('avg_score_chart')/div/div[1]/*[local-name()='svg' and namespace-uri()='http://www.w3.org/2000/svg']

我的HTML代码如下:

<div id="avg_score_chart" class="chart" style="height: 250px; color: black ! important; overflow: hidden; text-align: left;">
<div class="amcharts-main-div" style="position: relative;">
<div class="amcharts-chart-div" style="overflow: hidden; position: relative; text-align: left; width: 525px; height: 212px; padding: 0px;">
<svg version="1.1" style="position: absolute; width: 525px; height: 212px; top: 0.450012px; left: -0.5px;">
<desc>JavaScript chart by amCharts 3.17.1</desc>
<g>
<g>
<g>
<g>
<g>
<g>
<g transform="translate(60,52)">
<g transform="translate(96,41)">
<g transform="translate(96,123)">
<g transform="translate(96,123)">
<path cs="100,100" d="M0.5,0.5 L0.5,-81.5 L30.5,-81.5 L30.5,0.5 L0.5,0.5 Z" fill="rgb(242,244,28)" stroke="rgb(242,244,28)" fill-opacity="0.8" stroke-width="1" stroke-opacity="0.8">
</g>
<g transform="translate(318,123)">
<g transform="translate(318,123)">
<g transform="translate(318,123)">
</g>
</g>
<g>
<g>
<g>
<g>
<g>
<g>
<g>
<g>
<g>
<g>
<g>
</svg>

有人可以帮帮我吗?

2 个答案:

答案 0 :(得分:3)

请尝试关注XPath并告诉我问题是否仍然存在:

//div[@id="avg_score_chart"]//*[name()="svg"]

对于<g>元素:

//div[@id="avg_score_chart"]//*[name()="svg"]/*[name()="g"]

<强>更新

最后,这应该是最好的选择:

//div[@class="portlet light boxshadow"][contains(.,"Store Wise Performance")]/div//div[@class="amcharts-chart-div"]/*[name()="svg"]//*[name()="g"]/*[name()="path" and @fill="rgb(242,244,28)"]

答案 1 :(得分:2)

怎么样: //div[@id='avg_score_chart']//*[local-name()='svg']/*[*[local-name()='path']]

您可以在其中找到任何带有&#39;路径的元素。一个&#39; svg&#39;一个&#39; div内的元素id为&av; _ avg_score_chart&#39;。

的元素

编辑:将xpath放在代码块中