web自动化中踩过的低级错误坑(python+selenium)


1.定位了元素没有做下一步操作,比如,点击、输入等功能,而报错,报错信息如下:

 

2.上传图片时,定位元素,应该定位input标签,点击页面input标签肉眼没有看到定位到任何元素,以为无法成功,实际上只要有input标签被定位到是都可以上传图片的!

3.定义页面基础类时,初始化webdiver,传参数的时候没有对参数driver赋默认None值,即一个默认参数,导致页面报错如下:

传人默认参数,在调用self.main=Main()时,就可以不传入参数了

class BasePage():
    _base_url = ""

    def __init__(self, driver: WebDriver = None):#就是因为这里没有传None!!❗️❗️⚠️
        self._driver = None
        if self._driver is None:
            ops_chrome = webdriver.ChromeOptions()
            ops_chrome.debugger_address = "127.0.0.1:9222"
            self._driver = webdriver.Chrome(options=ops_chrome)
        else:
            self._driver = driver
        if self._base_url != "":#这里的意思是如果_base_url不为空的话,就执行跳转到某个页面,这个页面的url其实是子类重写了父类的类属性
            self._driver.get(self._base_url)
        self._driver.implicitly_wait(5)

4. 有时候报错有可能不是没有定位到元素,而是时间太快,页面没有加载出来,这个时候可以加一个等待时间再试一下

5.封装定位元素的方法,应该将by和locate都传进去,使用起来更加灵活!

    def find(self, by, locate):
        return self._driver.find_element(by, locate)

6.在po设计模式中,所有的页面都要继承页面基类(BasePage)

7.定位元素的时候,一定要和driver打开的页面是一致的。今天用已登录的页面去定位百度页面右上角的设置,发现老是提示页面定位不到元素的错误,其实就是因为driver打开的浏览器是没有任何登录信息的百度页面,而我是去定位到的已登录状态的百度页面,因此这两个不是同一个页面!!!以后定位元素,一定要记住这个坑,并不是这个元素没有id属性.

8.定位比如搜索设置中的悬浮窗时,打开控制台中使用快捷键是定位不到的,需要选中要查看的元素,右键,点击菜单中的检查!!

9.如果没有定位到某个元素的时候,可以打印driver.page_source,来判断该元素是否在当前页面:

assert 's_btn_wr' in self.driver.page_source

 

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM