python+selenium+webdriver_wait和弹框处理机制(3)

前言:
在IT行業學會閲讀官網資料是一項必備技能。

https://selenium-python.readthedocs.io/

在这里插入图片描述
正文:
1.等待:

  • 隱式等待:
    設置等待時間,輪詢查找元素是否出現(默認0.5),如果沒有出現抛出異常self.driver.implicitly_wait(3)
    缺點:全局,需要find的元素找到,多個find元素之間,若不重要的元素一直刷新不出來,會影響整體時間.
  • 顯示等待:
    在代碼中定義的等待,儅條件發生時才繼續執行代碼,webdriverwait配合until()和until_not()程序每隔一段時間(默認0.5S)進行條件判斷,成立,執行,不成立繼續等待,直到設置的最長時間
  • 强制等待:綫程休眠一段時間,time.sleep(3):固定等待3s
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions
from selenium.webdriver.support.wait import WebDriverWait


class Testwait():

    def setup(self):
        self.driver = webdriver.Chrome()
        self.driver.get('https://www.baidu.com/')
        # 顯示等待
        self.driver.implicitly_wait(3)
    def test_wait(self):
        self.driver.find_element_by_id('kw').send_keys('python')
        self.driver.find_element_by_id('su').click()
        # 隱式等待,采用内置的expected_conditions(或者自己寫判斷函數)
        WebDriverWait(self.driver,10).until(expected_conditions.visibility_of_element_located((By.XPATH,'//*[@id="3001"]/div/div/div/div[1]/h3/div/a')))

2.元素定位

  • 瀏覽器自帶調試功能
    //:表示所有元素,包括子孫
    /:表示子元素
    注意:appium原生不支持css定位,但是基於網頁形式的支持,css定位效率高
    console调试:
    $(“css表达式”)
    $x(“xpath表达式”)
    $("#id名")
    $(".class表达式")

//表示所有元素,包括子孫这里插入图片描述
3.文件上传
可以使用send_keys()
4.弹框处理机制
有时候会遇到js生成的alert/confirm/prompt,可以使用switch_to.alert()方法定位,然后text/accept/dismiss/send_keys等方法进行操作
alert:一般情况无法定位,只有先获取才能操作
accept/dismiss:模拟点击确认或取消按钮
在这里插入图片描述

import time

from test.base import Base


class TestJS(Base):
    def test_alert(self):
        self.driver.get('https://www.runoob.com/try/try.php?filename=tryjs_alert')
        self.driver.switch_to_frame('iframeResult')
        self.driver.find_element_by_xpath('/html/body/input').click()
        time.sleep(2)
        self.driver.switch_to.alert.accept()
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值