selenium get_attribute搜索结果为多个时
时间: 2024-03-23 11:41:40 浏览: 89
当使用Selenium的`get_attribute`方法在多个元素上执行时,它将返回一个包含所有元素属性值的列表。你可以使用索引来获取特定元素的属性值。
例如,如果你想获取第一个匹配元素的属性值,可以这样:
```python
element = driver.find_elements_by_xpath("your xpath")[0]
attribute_value = element.get_attribute("your attribute")
```
如果你想获取所有匹配元素的属性值,可以使用循环:
```python
elements = driver.find_elements_by_xpath("your xpath")
for element in elements:
attribute_value = element.get_attribute("your attribute")
print(attribute_value)
```
相关问题
selenium的xpath的get_attribute如何取多个元素
在 Selenium 中,使用 `find_elements_by_xpath()` 方法来查找多个元素,然后可以循环遍历这些元素,并使用 `get_attribute()` 方法获取每个元素的属性值。
例如:
```python
elements = driver.find_elements_by_xpath("//a")
for element in elements:
print(element.get_attribute("href"))
```
这段代码会查找所有的 `a` 元素,然后遍历这些元素,并打印每个元素的 `href` 属性值。
def get_teleplay_links(nums=1000): with open('all_links.csv', 'r')as opener: link_list = opener.readlines() print(link_list) link_list = set(link.strip() for link in link_list) # print(link_list) browser.get(url) links = browser.find_elements_by_xpath("html//div[@class='list-wp']//a[@target='_blank']") browser.execute_script("window.scrollTo(0, document.body.scrollHeight)") time.sleep(1) try: while len(links) < nums: print('nums:', len(links)) browser.execute_script("window.scrollTo(0, document.body.scrollHeight)") time.sleep(random.randint(3, 5)) more = browser.find_element_by_xpath("html//a[@class='more']") while len(browser.window_handles) > 1: browser.switch_to.window(browser.window_handles[1]) browser.close() browser.switch_to.window(browser.window_handles[0]) print(more.get_attribute('href')) more.click() links = browser.find_elements_by_xpath("html//div[@class='list-wp']//a[@target='_blank']") for link in links: href = link.get_attribute('href') print('href', href) if href not in link_list: link_list.add(href) else: print('exist!') except Exception: with open('all_links.csv', 'w')as opener: for href in link_list: opener.write(href + '\n')
这段代码的作用是获取电视剧链接,并将新的链接存储到一个名为 "all_links.csv" 的文件中。具体流程如下:
1. 打开名为 "all_links.csv" 的文件,读取其中的链接列表,存储到 link_list 变量中。
2. 将 link_list 中的每个链接去掉首尾空格,存储到 set 中,这样可以去重。
3. 打开一个网页,通过 xpath 定位到网页中的电视剧链接,存储到 links 变量中。
4. 将网页滚动到底部,等待 1 秒,尝试查找 "更多" 按钮。
5. 如果找到 "更多" 按钮,就点击它,等待新的电视剧链接加载完成。
6. 将新的电视剧链接存储到 link_list 中,如果链接已经存在于 link_list 中,则忽略。
7. 如果出现异常,就将 link_list 中的链接写入到 "all_links.csv" 文件中。
需要注意的是,这段代码中使用了 Selenium 库来模拟浏览器操作,因此需要先安装该库。另外,代码中的 url 变量没有给出,需要在调用该函数之前先定义好。
阅读全文