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

select(Python)-选择

杜辰龙
2023-03-14
问题内容

现在,我的脚本转到页面并在出现错误消息之前打开下拉列表“ Vijesti”中的第二个对象。

这是错误:

StaleElementReferenceException:消息:在缓存中找不到元素-自查找页面以来,页面可能已更改

从硒站点:

当对元素的引用现在“陈旧”时抛出。陈旧意味着元素不再出现在页面的DOM上。StaleElementReferenceException的可能原因包括但不限于:

  • 您不再位于同一页面上,或者自找到元素以来该页面可能已刷新。
  • 自找到元素以来,该元素可能已被删除并重新添加到屏幕上。例如正在重定位的元素。当值更新并重建节点时,这通常会在JavaScript框架中发生。
  • 元素可能位于iframe或其他刷新的上下文中。

我要选择每个对象,然后将其打开。

这是网址中的SELECT部分​​:

<select id="kategorija" name="kategorija">
<option value="0">Kategorija</option>
<option value="12">Vijesti</option>
<option value="8">Biznis</option>
<option value="5">Sport</option>
<option value="2">Magazin</option>
<option value="7">Lifestyle</option>
<option value="3">Scitech</option>
<option value="6">Auto</option> 
</select>

码:

from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support.ui import Select
import time

driver = webdriver.Firefox()

driver.get("http://www.klix.ba/")

assert "Klix" in driver.title

elem = driver.find_element_by_name("q")

elem.send_keys("test")

elem.send_keys(Keys.RETURN)


select = Select(driver.find_element_by_name('kategorija'))

all_options = [o.get_attribute('value') for o in select.options]

for x in all_options:
    select.select_by_value(x)
    time.sleep(3)

这是我进行测试的网址。


问题答案:

__从下拉列表中选择一个项目后 ,页面会自动刷新

您需要select在每个选择的选项上“重新查找”元素:

select = Select(driver.find_element_by_name('kategorija'))

for index in range(len(select.options)):
    select = Select(driver.find_element_by_name('kategorija'))
    select.select_by_index(index)

    # grab the results


 类似资料:
  • Select 选择器 当选项过多时,使用下拉菜单展示并选择内容。 基础用法 适用广泛的基础单选 v-model的值为当前被选中的el-option的 value 属性值 <template> <el-select v-model="value" placeholder="请选择"> <el-option v-for="item in options" :key=

  • 当选项过多时,使用下拉菜单展示并选择内容。 基础用法 适用广泛的基础单选 v-model的值为当前被选中的el-option的 value 属性值 <template> <el-select v-model="value" placeholder="请选择"> <el-option v-for="item in options" :key="item.value

  • Select 选择器 当选项过多时,使用下拉菜单展示并选择内容。 基础用法 适用广泛的基础单选 :::demo value的值为当前被选中的Option的 value 属性值 constructor(props) { super(props); this.state = { options: [{ value: '选项1', label: '黄金糕'

  • 当选项过多时,使用下拉菜单展示并选择内容。 基础用法 适用广泛的基础单选 el-option 的属性 label和value是必填的。 <!--你可以通过 model 来获取每次选择的值--> <!--或者通过绑定 (modelChange)=handle 来获得每次值改变的触发--> <el-select [model]="value" placeholder="请选择" (modelChang

  • 我是新来的蟒蛇。我真的很想知道如何从SELECT中获得我的选项。在下面列出的情况下,我想选择select标记的第一个选项。 我尝试了很多方法,但都失败了。当前错误为“元素当前不可见,可能无法操作”。使用索引不会出错,但不会显示任何内容 没有打印源代码的输出如下所示: 这是网站的源代码 我注意到,实际上它设法检测选择的所有8个选项,但就在尝试更新选项时,出现了一些错误。 更具体地说,错误是(万一有用

  • Select 列选择器 1.3.0 平台差异说明 App H5 微信小程序 支付宝小程序 百度小程序 头条小程序 QQ小程序 √ √ √ √ √ √ √ 基本使用 所有的配置模式中,都要求传入数组的元素(对象)中含有value和label属性(可以通过value-name和label-name参数自定义), value用于在回调时,区别选择了哪一个(针对开发者),label用于展示在选择器中,供用