① 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 ?