① selenium python 针对js生成的下拉列表,如何选择隐藏的选项

自己打开JS的源代码。然后手工将隐藏项解析出来。这个最简单。因为你是一个测试脚本,不是通用的爬行器。所以不需要处理JS。

另外看你的现在的情形,它不是个隐藏项。只是JS实现的界面控件。在JS代码和html代码里,或者是ajax的JSON响应里可以找得到。

② selenium+python怎么获取非select下拉框中的内容

当前值直接获取text就行了。下拉值就获取一共几个div,然后获取一下div的text属性。就出来了

③ python selenium drag_and_drop()和drag_and_drop_with_offset()怎么使用

用selenium做自动化,有时候会遇到需要模拟鼠标操作才能进行的情况,比如单击、双击、点击鼠标右键、拖拽等等。而selenium给我们提供了一个类来处理这类事件——ActionChains

selenium.webdriver.common.action_chains.ActionChains(driver)

这个类基本能够满足我们所有对鼠标操作的需求。

1.ActionChains基本用法

首先需要了解ActionChains的执行原理,当你调用ActionChains的方法时,不会立即执行,而是会将所有的操作按顺序存放在一个队列里,当你调用perform()方法时,队列中的时间会依次执行。

这种情况下我们可以有两种调用方法:

  • 链式写法

    menu = driver.find_element_by_css_selector(".nav")
    hidden_submenu = driver.find_element_by_css_selector(".nav #submenu1")

    ActionChains(driver).move_to_element(menu).click(hidden_submenu).perform()
  • 1

  • 2

  • 3

  • 4

  • 分步写法

    menu = driver.find_element_by_css_selector(".nav")
    hidden_submenu = driver.find_element_by_css_selector(".nav #submenu1")

    actions = ActionChains(driver)
    actions.move_to_element(menu)
    actions.click(hidden_submenu)
    actions.perform()
  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 两种写法本质是一样的,ActionChains都会按照顺序执行所有的操作。

    2.ActionChains方法列表

    click(on_element=None) ——单击鼠标左键

    click_and_hold(on_element=None) ——点击鼠标左键,不松开

    context_click(on_element=None) ——点击鼠标右键

    double_click(on_element=None) ——双击鼠标左键

    drag_and_drop(source, target) ——拖拽到某个元素然后松开

    drag_and_drop_by_offset(source, xoffset, yoffset) ——拖拽到某个坐标然后松开

    key_down(value, element=None) ——按下某个键盘上的键

    key_up(value, element=None) ——松开某个键

    move_by_offset(xoffset, yoffset) ——鼠标从当前位置移动到某个坐标

    move_to_element(to_element) ——鼠标移动到某个元素

    move_to_element_with_offset(to_element, xoffset, yoffset) ——移动到距某个元素(左上角坐标)多少距离的位置

    perform() ——执行链中的所有动作

    release(on_element=None) ——在某个元素位置松开鼠标左键

    send_keys(*keys_to_send) ——发送某个键到当前焦点的元素

    send_keys_to_element(element, *keys_to_send) ——发送某个键到指定元素

    接下来用示例来详细说明和演示每一个方法的用法:

    3.代码示例

    1. 点击操作

    代码:

  • # -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsfrom time import sleep



  • driver = webdriver.Firefox()

  • driver.implicitly_wait(10)

  • driver.maximize_window()

  • driver.get('')


  • click_btn = driver.find_element_by_xpath('//input[@value="click me"]') # 单击按钮doubleclick_btn = driver.find_element_by_xpath('//input[@value="dbl click me"]') # 双击按钮rightclick_btn = driver.find_element_by_xpath('//input[@value="right click me"]') # 右键单击按钮ActionChains(driver).click(click_btn).double_click(doubleclick_btn).context_click(rightclick_btn).perform() # 链式用法print driver.find_element_by_name('t2').get_attribute('value')


  • sleep(2)

  • driver.quit()

  • 结果:

  • [CLICK][DOUBLE_CLICK][RIGHT_CLICK]1

  • 2.鼠标移动

    示例代码:

  • # -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsfrom time import sleep


  • driver = webdriver.Firefox()

  • driver.implicitly_wait(10)

  • driver.maximize_window()

  • driver.get('')


  • write = driver.find_element_by_xpath('//input[@value="Write on hover"]') # 鼠标移动到此元素,在下面的input框中会显示“Mouse moved”blank = driver.find_element_by_xpath('//input[@value="Blank on hover"]') # 鼠标移动到此元素,会清空下面input框中的内容result = driver.find_element_by_name('t1')


  • action = ActionChains(driver)

  • action.move_to_element(write).perform() # 移动到write,显示“Mouse moved”print result.get_attribute('value')# action.move_to_element(blank).perform()action.move_by_offset(10, 50).perform() # 移动到距离当前位置(10,50)的点,与上句效果相同,移动到blank上,清空print result.get_attribute('value')


  • action.move_to_element_with_offset(blank, 10, -40).perform() # 移动到距离blank元素(10,-40)的点,可移动到write上print result.get_attribute('value')


  • sleep(2)

  • driver.quit()242526272829

  • 结果

  • Mouse moved


  • Mouse moved123

  • 一般很少用位置关系来移动鼠标,如果需要,可参考下面的链接来测量元素位置

    3.拖拽

    代码:

  • # -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsfrom time import sleep


  • driver = webdriver.Firefox()

  • driver.implicitly_wait(10)

  • driver.maximize_window()

  • driver.get('ls.htm')


  • dragger = driver.find_element_by_id('dragger') # 被拖拽元素item1 = driver.find_element_by_xpath('//div[text()="Item 1"]') # 目标元素1item2 = driver.find_element_by_xpath('//div[text()="Item 2"]') # 目标2item3 = driver.find_element_by_xpath('//div[text()="Item 3"]') # 目标3item4 = driver.find_element_by_xpath('//div[text()="Item 4"]') # 目标4action = ActionChains(driver)

  • action.drag_and_drop(dragger, item1).perform() # 1.移动dragger到目标1sleep(2)

  • action.click_and_hold(dragger).release(item2).perform() # 2.效果与上句相同,也能起到移动效果sleep(2)

  • action.click_and_hold(dragger).move_to_element(item3).release().perform() # 3.效果与上两句相同,也能起到移动的效果sleep(2)# action.drag_and_drop_by_offset(dragger, 400, 150).perform() # 4.移动到指定坐标action.click_and_hold(dragger).move_by_offset(400, 150).release().perform() # 5.与上一句相同,移动到指定坐标sleep(2)

  • driver.quit()2425262728

  • 结果:

  • dropped dropped dropped dropped1

  • 一般用坐标定位很少,用上例中的方法1足够了,如果看源码,会发现方法2其实就是方法1中的drag_and_drop()的实现。注意:拖拽使用时注意加等待时间,有时会因为速度太快而失败。

    4.按键

    模拟按键有多种方法,能用win32api来实现,能用SendKeys来实现,也可以用selenium的WebElement对象的send_keys()方法来实现,这里ActionChains类也提供了几个模拟按键的方法。

    代码1:

  • # -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsfrom time import sleep


  • driver = webdriver.Firefox()

  • driver.implicitly_wait(10)

  • driver.maximize_window()

  • driver.get('press.htm')


  • key_up_radio = driver.find_element_by_id('r1') # 监测按键升起key_down_radio = driver.find_element_by_id('r2') # 监测按键按下key_press_radio = driver.find_element_by_id('r3') # 监测按键按下升起enter = driver.find_elements_by_xpath('//form[@name="f1"]/input')[1] # 输入框result = driver.find_elements_by_xpath('//form[@name="f1"]/input')[0] # 监测结果# 监测key_downkey_down_radio.click()

  • ActionChains(driver).key_down(Keys.CONTROL, enter).key_up(Keys.CONTROL).perform()print result.get_attribute('value')# 监测key_upkey_up_radio.click()

  • enter.click()

  • ActionChains(driver).key_down(Keys.SHIFT).key_up(Keys.SHIFT).perform()print result.get_attribute('value')# 监测key_presskey_press_radio.click()

  • enter.click()

  • ActionChains(driver).send_keys('a').perform()print result.get_attribute('value')

  • driver.quit()242526272829303132333435

  • 结果:

  • key downed charCode=[0] keyCode=[17] CTRLkey upped charCode=[0] keyCode=[16] NONEkey pressed charCode=[97] keyCode=[0] NONE123

  • 示例2:

    代码:

  • # -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsfrom selenium.webdriver.common.keys import Keysfrom time import sleep


  • driver = webdriver.Firefox()

  • driver.implicitly_wait(10)

  • driver.maximize_window()


  • driver.get('hel.htm')


  • input1 = driver.find_elements_by_tag_name('input')[3]

  • input2 = driver.find_elements_by_tag_name('input')[4]


  • action = ActionChains(driver)

  • input1.click()

  • action.send_keys('Test Keys').perform()

  • action.key_down(Keys.CONTROL).send_keys('a').key_up(Keys.CONTROL).perform() # ctrl+aaction.key_down(Keys.CONTROL).send_keys('c').key_up(Keys.CONTROL).perform() # ctrl+caction.key_down(Keys.CONTROL, input2).send_keys('v').key_up(Keys.CONTROL).perform() # ctrl+vprint input1.get_attribute('value')print input2.get_attribute('value')


  • driver.quit()2425262728

  • 结果:

  • Test Keys

  • Test Keys12

  • 复制粘贴用WebElement< input >.send_keys()也能实现,大家可以试一下,也可以用更底层的方法,同时也是os弹框的处理办法之一的win32api,有兴趣也可以试试SendKeys、keybd_event

④ python自动化执行时,定位下拉框中值,不在当前的form中,如何定位,请指教

1. 个别情况下用到Actionchain的悬停功能,使下拉框展开,才能定位到到页面的元素。
2. 一般用到Select,有三种方式实现下拉框内容的选择,任选其一。定位元素时,要先定位到下拉菜单,而不是直接定位下拉菜单里面的选项,示例如下:
from selenium import webdriver
from selenium.webdriver.support.select import Select
driver = webdriver.Chrome()
# 根据索引选择(索引要字符串格式)
Select(driver.find_element_by_id("id_name")).select_by_index("2")
# 根据value值选择
Select(driver.find_element_by_id("id_name")).select_by_value("值")
# 根据文本值选择
Select(driver.find_element_by_id("id_name")).select_by_visible_text("文本内容")
driver.quit()

⑤ python+selenium 定位页面中存在多个相同的下拉框,could not be scrolled into view异常

可以用xpath......m.find_element_by_xpath("//option[@value='1']").click(),它的value对应京东里面的是1,2,3,4这个。。。在者,找到下拉框的时候貌似不需要调用click()试试呗,这个xpath不行就用长的。。。/html/body/div[8]/div/div[2]/div/div/div/div/div[2]/div[1]/select[1]/option[25]

⑥ selenium-获取下拉选择框value默认的文本,而不是下拉框所有的文本值

我来答。
首先,Select类功能中
all_selected_options: 获取下拉菜单和列表中被选中的所有选项内容
first_selected_option: 获取下拉菜单和列表的第一个选项
所以呢,可以这样写,
----
#定位省份类型字段,作为Select类的对象实例
select_province_type = Select(self.driver.find_element_by_class_name('province'))
#检查默认选项是否为'天津'
self.assertTrue(select_province_type.first_selected_option.text == '天津')

⑦ python+selenium自动化测试定位下拉菜单并点击

那就改用点击来解决.
先点击倒三角按钮, 然后点击option value="132"
另外select标签怎么有个editable=false ?