1

他に何もせずに move_to_elemen と hover スクリプトを実行してみましたが、動作しているようです:

さて、私は実際にホバーを使用できるようで、move_to_element が機能しているようです...問題、高速になり、次のコマンドが機能するためにメニューを表示する必要があることです。

基本的に私の元の質問には欠陥があるため、これらのいくつかを連鎖させようとした後、より具体的な質問をします.


以下を更新してください。要素を見つけているようですが、非常に高速に実行されるため、メニューに表示される以下のコードが見つかりません。

私は数週間これと戦っており、ある程度の進歩を遂げましたが、(前回の実行で)要素をクリックした後になぜ機能するのか混乱していますが、新たに開始してスクリプトを実行すると停止し、最初のものを見つけることができませんチェーン内の要素 (menuitem4)。私が探している要素は、menuitem4(settings) をマウスでホバーするかクリックしたときにのみ表示されます。ブラウザのキャッシュからこの情報を取得している場合、このキャッシュ情報をスクレイピング/検索の場所に人為的に配置できますか?

待機するところまで来ました。設定ドロップダウンにマウスを合わせると、自動的に下に移動して適切なボタンが見つかり、すべてが問題なく動作します(最初の実行時)。どういうわけかマウスを設定の上に置く方法を理解するのを手伝ってくれたら、とても感謝しています。

stackoverflow で見つけたすべてのバリエーションと、Google で見つけた他のソリューションを試しましたが、move_to_element は機能しません。また、これがどれほど有効かはわかりませんが、Pythonでホバーが壊れていることを示す複数の投稿を読みました。

Firefox IDE バージョンは問題なく動作します。私が試したいくつかのランダムなものが表示されます。私が試したものをさらに含めることもできますが、単純なものが欠けている可能性があります。

これが私が見つけたもので、識別の設定は次のとおりです。

ユニークなセレクター:

topMenuItem4 > a:nth-child(1) > span:nth-child(1)

外側の HTML:

<span textid="242">Settings</span>

XPath:

/html/body/div[2]/ul[2]/li[4]/a/span

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support.ui import Select
from selenium.common.exceptions import NoSuchElementException
from selenium.common.exceptions import ElementNotVisibleException
from selenium.webdriver.common.action_chains import ActionChains
from selenium.webdriver.support.ui import WebDriverWait
import unittest, time, re

class Testpythoncase1(unittest.TestCase):
    def setUp(self):
        self.driver = webdriver.Firefox()
        self.driver.implicitly_wait(30)
        self.base_url = "http://192.168.0.135"
        self.verificationErrors = []
        self.accept_next_alert = True
    
    def test_pythoncase1(self):
        driver = self.driver
        driver.get(self.base_url + "/login.htm")
        driver.find_element_by_name("password").send_keys("456")
        driver.find_element_by_xpath("//input[@value='Submit']").click()
    #driver.implicitly_wait(300)
    settings = driver.find_element_by_xpath("//*[@id='topMenuItem4']")
        ActionChains(driver).move_to_element(settings).perform()
    #driver.find_element_by_xpath("//li[@id='topMenuItem4']/ul/li[6]/a/span").click()
    #driver.find_element_by_xpath("//li[@id='topMenuItem4']").click()
    #driver.implicitly_wait(300)
    #element = WebDriverWait(driver, 10).until(lambda x: x.find_element_by_xpath("settings"))
    element = WebDriverWait(driver, 10).until(lambda x: x.find_element_by_xpath("//li[@id='topMenuItem4']/ul/li[6]/a/span"))
    #ActionChains(driver).move_to_element(settings).perform()
    driver.find_element_by_xpath("//li[@id='topMenuItem4']/ul/li[6]/a/span").click()
    is_disappeared = WebDriverWait(driver, 30, 1, (ElementNotVisibleException))
    ActionChains(driver).move_to_element(settings).perform()
    #until_not(lambda x: x.find_element_by_id().is_displayed("//li[@id='topMenuItem4']/ul/li[6]/a/span"))
        driver.find_element_by_xpath("//li[@id='topMenuItem4']/ul/li[6]/a/span").click()
        driver.find_element_by_name("297").clear()
        driver.find_element_by_name("297").send_keys("")
        driver.find_element_by_name("297").clear()
        driver.find_element_by_name("297").send_keys("192.168.0.10")
        driver.find_element_by_name("305").clear()
        driver.find_element_by_name("305").send_keys("")
        driver.find_element_by_name("305").clear()
        driver.find_element_by_name("305").send_keys("poly3")
        driver.find_element_by_xpath("//button[@onclick='submitForm()']").click()
        #driver.find_element_by_id("popupbtn0").click()
        #driver.close()
    driver.find_element_by_name("30533").send_keys("poly3")
    
    def is_element_present(self, how, what):
        try: self.driver.find_element(by=how, value=what)
        except NoSuchElementException, e: return False
        return True
    
    def is_alert_present(self):
        try: self.driver.switch_to_alert()
        except NoAlertPresentException, e: return False
        return True
    
    def close_alert_and_get_its_text(self):
        try:
            alert = self.driver.switch_to_alert()
            alert_text = alert.text
            if self.accept_next_alert:
                alert.accept()
            else:
                alert.dismiss()
            return alert_text
        finally: self.accept_next_alert = True
    
    def tearDown(self):
        self.driver.quit()
        self.assertEqual([], self.verificationErrors)

if __name__ == "__main__":
    unittest.main()
4

0 に答える 0