我正在使用selenium,我需要找到一些selenium Web元素的XPath。
例如:
import selenium.webdriver
driver = selenium.webdriver.Firefox()
element = driver.find_element_by_xpath(<some_xpath>)
elements = element.find_elements_by_xpath(<some_relative_xpath>)
for e in elements:
print e.get_xpath()
我知道我不能从元素本身获取XPath,但是是否有一种不错的方法来获取它呢?
我尝试使用lxml解析HTML,但它无法识别我通过的XPath
<some_xpath>
,即使driver.find_element_by_xpath(<some_xpath>)
确实设法找到了该元素。 最佳答案
lxml
可以使用 getpath()
方法为您自动生成绝对绝对路径。
示例(使用wikipedia主页,获取徽标的xpath表达式):
import urllib2
from lxml import etree
data = urllib2.urlopen("https://en.wikipedia.org")
tree = etree.parse(data)
element = tree.xpath('//div[@id="p-logo"]/a')[0]
print tree.getpath(element)
打印:
/html/body/div[4]/div[2]/div[1]/a