selenium

简介

selenium使用JavaScript模拟真实用户对浏览器进行操作。测试脚本执行时,浏览器自动按照脚本代码做出点击,输入,打开,验证等操作,就像真实用户所做的一样,从终端用户的角度测试应用程序。

与python集成

from selenium import webdriver

driver = webdriver.Firefox()

driver.get("http://www.baidu.com")
driver.find_element_by_id("kw").send_keys("selenium")
driver.find_element_by_id("su").click()
driver.quit()

selenium可以操纵各大主流浏览器chrome、firefox、ie等等,但需要下载相应的驱动包

chrome: http://chromedriver.storage.googleapis.com/index.html

firefox:https://github.com/mozilla/geckodriver/releases/

ie:http://selenium-release.storage.googleapis.com/index.html

webdriver(即:浏览器对象)基本使用方法

  1. 打开关闭标签页

     #打开
    def get(self, url) #关闭
    def close(self) #退出浏览器
    def quit(self)
  2. 设置浏览器宽高

     def set_window_size(self, width, height, windowHandle='current'):
    """
    Sets the width and height of the current window. (window.resizeTo) :Args:
    - width: the width in pixels to set the window to
    - height: the height in pixels to set the window to :Usage:
    driver.set_window_size(800,600)
    """
  3. 对象定位

    #通过id方式定位

    driver.find_element_by_id("kw")

     #通过name方式定位
    driver.find_element_by_name("wd") #通过tag name方式定位
    driver.find_element_by_tag_name("input") #通过class name 方式定位
    driver.find_element_by_class_name("s_ipt") #通过CSS方式定位
    driver.find_element_by_css_selector("#kw") #通过xphan方式定位
    driver.find_element_by_xpath("//input[@id='kw']") #通过link方式定位
    driver.find_element_by_link_text("贴 吧") #Partial Link Text 定位
    driver.find_element_by_partial_link_text("贴") #通过by指定方法类型定位
    driver.find_element(By.ID, 'foo')
  4. 定位一组元素

     #与上面类似加上s,但上面会抛出NoSuchElementException,下面找不到则返回empty list
    #通过by指定方法类型定位
    driver.find_elements(By.ID, 'foo')
  5. 框架和窗口定位

     def switch_to(self):
    """
    :Returns:
    - SwitchTo: an object containing all options to switch focus into :Usage:
    element = driver.switch_to.active_element
    alert = driver.switch_to.alert
    driver.switch_to.default_content()
    driver.switch_to.frame('frame_name')
    driver.switch_to.frame(1)
    driver.switch_to.frame(driver.find_elements_by_tag_name("iframe")[0])
    driver.switch_to.parent_frame()
    driver.switch_to.window('main')
    """
  6. 执行js

     def execute_script(self, script, *args):
    """
    Synchronously Executes JavaScript in the current window/frame. :Args:
    - script: The JavaScript to execute.
    - \*args: Any applicable arguments for your JavaScript. :Usage:
    driver.execute_script('return document.title;')
    """ def execute_async_script(self, script, *args):
    """
    Asynchronously Executes JavaScript in the current window/frame. :Args:
    - script: The JavaScript to execute.
    - \*args: Any applicable arguments for your JavaScript. :Usage:
    script = "var callback = arguments[arguments.length - 1]; " \
    "window.setTimeout(function(){ callback('timeout') }, 3000);"
    driver.execute_async_script(script)
    """

webelement(元素)基本使用方法

  1. 点击

     driver.find_element_by_id("su").click()
    driver.find_element_by_id("su").submit()
  2. 输入文本

     driver.find_element_by_id("kw").send_keys("xxx")
  3. 获取属性/文本

     driver.find_element_by_id("kw").text()
    driver.find_element_by_id("kw").get_attribute()
    driver.find_element_by_id("kw").get_property()
  4. 层次定位

     #与webdiriver操作一样,可以以当前元素为父元素查找子元素
    parent = driver.find_element(By.ID, 'parent')
    parent.find_element(By.ID, 'child')

python爬虫入门(4)----- selenium的更多相关文章

  1. Python爬虫入门一之综述

    大家好哈,最近博主在学习Python,学习期间也遇到一些问题,获得了一些经验,在此将自己的学习系统地整理下来,如果大家有兴趣学习爬虫的话,可以将这些文章作为参考,也欢迎大家一共分享学习经验. Pyth ...

  2. python爬虫入门-开发环境与小例子

    python爬虫入门 开发环境 ubuntu 16.04 sublime pycharm requests库 requests库安装: sudo pip install requests 第一个例子 ...

  3. python爬虫动态html selenium.webdriver

    python爬虫:利用selenium.webdriver获取渲染之后的页面代码! 1 首先要下载浏览器驱动: 常用的是chromedriver 和phantomjs chromedirver下载地址 ...

  4. Python爬虫入门教程 48-100 使用mitmdump抓取手机惠农APP-手机APP爬虫部分

    1. 爬取前的分析 mitmdump是mitmproxy的命令行接口,比Fiddler.Charles等工具方便的地方是它可以对接Python脚本. 有了它我们可以不用手动截获和分析HTTP请求和响应 ...

  5. Python爬虫入门教程 43-100 百思不得姐APP数据-手机APP爬虫部分

    1. Python爬虫入门教程 爬取背景 2019年1月10日深夜,打开了百思不得姐APP,想了一下是否可以爬呢?不自觉的安装到了夜神模拟器里面.这个APP还是比较有名和有意思的. 下面是百思不得姐的 ...

  6. Python 爬虫入门(二)——爬取妹子图

    Python 爬虫入门 听说你写代码没动力?本文就给你动力,爬取妹子图.如果这也没动力那就没救了. GitHub 地址: https://github.com/injetlee/Python/blob ...

  7. Python爬虫入门之正则表达式

    在前面我们已经搞定了怎样获取页面的内容,不过还差一步,这么多杂乱的代码夹杂文字我们怎样把它提取出来整理呢?下面就开始介绍一个十分强大的工具,正则表达式! 1.了解正则表达式 正则表达式是对字符串操作的 ...

  8. Python爬虫入门之Cookie的使用

    本节我们一起来看一下Cookie的使用. 为什么要使用Cookie呢? Cookie,指某些网站为了辨别用户身份.进行session跟踪而储存在用户本地终端上的数据(通常经过加密) 比如说有些网站需要 ...

  9. Python爬虫入门之Urllib库的高级用法

    1.设置Headers 有些网站不会同意程序直接用上面的方式进行访问,如果识别有问题,那么站点根本不会响应,所以为了完全模拟浏览器的工作,我们需要设置一些Headers 的属性. 首先,打开我们的浏览 ...

  10. Python爬虫入门之Urllib库的基本使用

    那么接下来,小伙伴们就一起和我真正迈向我们的爬虫之路吧. 1.分分钟扒一个网页下来 怎样扒网页呢?其实就是根据URL来获取它的网页信息,虽然我们在浏览器中看到的是一幅幅优美的画面,但是其实是由浏览器解 ...

随机推荐

  1. Python实用笔记 (7)高级特性——切片

    列表L = ['Michael', 'Sarah', 'Tracy', 'Bob', 'Jack'] 取前3个元素 >>> L[0:3] ['Michael', 'Sarah', ' ...

  2. javaScript的三种储存方式

    (一).SessionStorage     会话储存 (二).localStorage           本地储存 (三).Cookier                   现实中为:饼干    ...

  3. linux就该这么学 第一天学习笔记

    题外话 在每天的网上冲浪中,一次无意间的点击,发现了linux就该这么学的网站,然后就看了一晚上,当时还是学生的我特别想要参加培训,可是碍于眼前的经济状况,只得将这个想法深深的藏在了心里,并加了一下网 ...

  4. 服务消费者(Feign-上)

    上一篇文章,讲述了Ribbon去做负载请求的服务消费者,本章讲述声明性REST客户端:Feign的简单使用方式 - Feign简介 Feign是一个声明式的Web服务客户端.这使得Web服务客户端的写 ...

  5. 调试HotSpot源代码

    之前的文章在Ubuntu 16.04上编译OpenJDK8的源代码 已经介绍过在Ubuntu上编译OpenJDK8的源代码,这一篇将介绍在Ubuntu上调试OpenJDK8源代码的2种方式. 1.GD ...

  6. h5手机摇一摇功能实现:基于html5重力感应DeviceMotionEvent事件监听手机摇晃

    DeviceMotionEven是html5提供的一个用来获取设备物理方向及运动的信息(比如陀螺仪.罗盘及加速计)的Dom事件,事件描述如下: deviceorientation:提供设备的物理方向信 ...

  7. 赞!7000 字学习笔记,一天搞定 MySQL

    MySQL数据库简介 MySQL近两年一直稳居第二,随时有可能超过Oracle计晋升为第一名,因为MySQL的性能一直在被优化,同时安全机制也是逐渐成熟,更重要的是开源免费的. MySQL是一种关系数 ...

  8. 区间dp(低价回文)

    [题目大意] 追踪每头奶牛的去向是一件棘手的任务,为此农夫约翰安装了一套自动系统.他在每头牛身上安装了一个电子身份标签,当奶牛通过扫描器的时候,系统可以读取奶牛的身份信息.目前,每个身份都是由一个字符 ...

  9. [POJ1852] Ants(思维题)

    题干 An army of ants walk on a horizontal pole of length l cm, each with a constant speed of 1 cm/s. W ...

  10. CentOS7下安装和配置SVN

    1. 由于是在CentOS7最小化安装的操作系统环境安装SVN,我们首先排除一些环境因素.在此首先关闭了防火墙,安装了vim文本编辑工具.   2. 使用yum install -y subversi ...