硒及;Python:使用动态XPATH查找元素

硒及;Python:使用动态XPATH查找元素,python,html,python-3.x,selenium,selenium-webdriver,Python,Html,Python 3.x,Selenium,Selenium Webdriver,我试图从一个非常具体的href中提取url,这个站点有许多非常有用的html路由!与此类似,提取此url的唯一方法是按照我的方式构建XPATH 但最大的问题是,它一直在变化,标签的一部分是静态的,而另一部分是动态的,有点随机 html如下所示: 注意:page\u name=“Laura”是我可以选择的名字 # Option 1 <span label="answer by Laura to Charles"> # Option 2 <span label=

我试图从一个非常具体的href中提取url,这个站点有许多非常有用的html路由!与此类似,提取此url的唯一方法是按照我的方式构建XPATH

但最大的问题是,它一直在变化,标签的一部分是静态的,而另一部分是动态的,有点随机

html如下所示: 注意:
page\u name=“Laura”
是我可以选择的名字

# Option 1
<span label="answer by Laura to Charles">
# Option 2
<span label="answer by Laura to Nina">
# Option 3
<span label="answer by Laura to Maria">
 <div >
  <a href="www.thisisawebsite.otherthings.blabla...>
# Option n
<span label="answer by Laura to THIS COULD BE ANY RANDOM NAME">
 <div >
  <a href="www.thisisawebsite.otherthings.blabla...>
其他尝试:

get_comment = WebDriverWait(self.driver, 2).until(
                            EC.presence_of_all_elements_located((
                                By.XPATH,
                                r'//span[(@label="answer by {}")]/div/a'.format(page_name)))
                        )[0].get_attribute('href')

如果您将其更改为

get_comment = WebDriverWait(self.driver, 2).until(
                            EC.presence_of_all_elements_located((
                                By.XPATH,
                                r'//span[contains(@label,"answer by {}")]/div/a'.format(page_name)))
                        )[0].get_attribute('href')

使用“=”时,它会搜索完全相同的字符串。这只允许您获得其中的一部分

非常感谢,这对Selenium用户非常重要欢迎:)
get_comment = WebDriverWait(self.driver, 2).until(
                            EC.presence_of_all_elements_located((
                                By.XPATH,
                                r'//span[contains(@label,"answer by {}")]/div/a'.format(page_name)))
                        )[0].get_attribute('href')