热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

selenium入门(二)

sel

    第一篇简单地介绍了一下如何用python打开一个浏览器,但没有详细说到安装的方法,这里简单补充一下。

    1)Google浏览器,我们只需安装后把Google浏览器的驱动放到python安装目录下即可如下图

   2)对于无界面PhantomJs浏览器,我们只需找一个目录把它解压后,找到它的bin目录然后把路径复制配到系统的环境变量即可。

bin目录

环境变量:



    进入正题前想向做测试的朋友安利一波一款脚本语言----perl。如果有打算做后台测试或者涉及后台开发的朋友可以了解一下,在linux写一些关于连数据库的脚本,做一些数据对比或修复我觉得perl比python更方便。

    面介绍了如何驱动浏览器,今天就来实操几个我认为还比较重要的函数。一开始对这些函数有点印象就可以,以后用多了就自然背下来了

页面请求操作

1.driver.get(url)  请求某个url对应的响应

2.refresh()  刷新页面操作

3.back()  回退到之前的页面

4.forward()  前进到之后的页面




获取断言信息的操作

1.current_url 获取当前访问页面url

2.title  获取当前浏览器标题

3.get_screenshot_as_png()  保存图片 比较少用,在selenium2中它返回一个二进制的数据需要用写文件的操作保存

4.get_screenshot_as_file(file)   直接保存 #常用测试完成后截图保存记录

5.page_source    网页源码 #常用于爬虫

元素的定位


1.直接调用型(推荐方式)

driver.find_element_by_xxx(value)

2.使用By类型(需要导入By)

from selenium.webdriver.common.by import By

driver.find_element(By.xxx,value)

    元素定位有8种,但我觉得只需要熟悉使用xpath或是css其中的一种就可以解决百分之90的问题(可能我遇到太低端了)。其它了解一下就可以,当然大神都是精通8种的.

driver.find_element_by_id(value)   #id属性值定位 
driver.find_element_by_name(value)  #name属性值定位 
driver.find_element_by_class_name(value)#class属性值定位 
driver.find_element_by_tag_name(value) #标签名属性值定位
driver.find_element_by_link_text(value)  #链接的文本 
driver.find_element_by_partial_link_text(value)#模糊匹配链接的文本 
driver.find_element_by_xpath(value)  #xpath路径 
driver.find_element_by_css_selector(value)#css选择器定位


    具体用法就不一一列举了,我提供的视频学习资料有详解.这里的介绍只是把视频中的一些重点指出并写成笔记方便日后查阅。



元素的操作

1)点击和输入

点击操作

element.click()

清空/输入操作(只能操作可以输入文本的元素)

element.clear() 清空输入框

element.send_keys(data) 输入数据

2)提交操作

element.submit()

3)获取元素信息

获取文本内容(既开闭标签之间的内容)

element.text

获取属性值(获取element元素的value属性的值)

element.get_attribute(value)

获取元素尺寸(了解)

element.size

获取元素是否可见(了解)

element.is_dispalyed()

    点击和输入数据必须掌握,其余用到地方不多。下一节会把这些函数运用起来做一个简单的自动填写汉堡王客户调查领礼物的小程序.以后吃汉堡王就可以快速免费加薯条了





推荐阅读
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 深入理解Tornado模板系统
    本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 本文介绍如何使用 Python 提取和替换 .docx 文件中的图片。.docx 文件本质上是压缩文件,通过解压可以访问其中的图片资源。此外,我们还将探讨使用第三方库 docx 的方法来简化这一过程。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
author-avatar
lovely夏的宠儿
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有