W30-python01-Selenium Web自动化基础--百度搜索案例-chrome浏览器为例

原理图

一、下载webdriver--chrome浏览器

根据本机浏览器的版本号下载对应的webdriver版本

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

二、安装selenium库

pip install selenium -i Simple Index

三、第一个Web自动化脚本

selenium实现Web自动化的基本步骤:

复制代码
import time
from selenium import webdriver
# 打开浏览器
driver = webdriver.Chrome()
# 隐式等待
driver.implicitly_wait(10)
# driver对象,提供了一系列操作网页的函数(功能)
driver.get('http://www.baidu.com')
#定位搜索框中输入
ele = driver.find_element('id','kw')
#搜索框中输入
ele.send_keys('雷军')
time.sleep(2)
#点击百度一下
driver.find_element('id','su').click()
#延时10s后关闭driver
time.sleep(10)
driver.quit();

四、知识点-定位元素

  1. id:在元素里面的,id="xxx" (id是唯一的)

ele = driver.find_element('id','username')

或 ele = driver.find_element(By.ID,'username')

  1. name:在元素里面的,name="xxx" (name不一定唯一)

ele = driver.find_element('name','username')

  1. class name:在元素里面的,class="xxx" (class基本不唯一)

ele = driver.find_element('class name','text_cmu')

  1. tag name:在元素最前面<后面这个单词,就是tagname (肯定不唯一)

ele = driver.find_element('tag name','input')

  1. link text:在<a>标签中间的文本,我们叫链接文本 (不一定唯一)

ele = driver.find_element('link text','淘宝网')

  1. partial link text:在<a>标签中间的文本包含某个文本就可以 (不一定唯一)

ele = driver.find_element('partial link text','淘宝')

  1. css selector:在元素dom结构上,右键-copy-copy selector

ele = driver.find_element('css selector','#username')

  1. xpath:在元素dom结构上,右键-copy-copy xpath

ele = driver.find_element('xpath','//*[@id="username"]')

五、知识点-操作元素

常用操作

|---------------|-------------------------|------------------------------------------------------------------------------------|
| send_keys | 输入 | driver.find_element('xpath','//*[@id="password"]').send_keys('123456') |
| click | 点击 | driver.find_element('xpath','//*[@id="loginform"]/div/div[6]/a').click() |
| text | 获取文本 | nickname = driver.find_element('xpath','//a[@class="red userinfo"]').text |
| get_attribute | 获取属性(元素里面 属性=值,都可以通过它获取 | ele = driver.find_element('link text','淘宝网') print(ele.get_attribute('outerHTML')) |

一般来说,一二步骤是连写的

driver.find_element('xpath','//*[@id="password"]').send_keys('123456')

六、Web自动化报错

报错1:no such element (在网页上没找到这个元素)

原因1:页面存在跳转或者延迟加载,导致元素还没有加载完成,代码就已经跑完了

解决方案:添加隐式等待

复制代码
# 添加隐式等待
driver.implicitly_wait(5)

原因2:定位方式错误。比如xpath写错,classname带空格等

解决方案:更换定位方式

相关推荐
Bellafu6664 分钟前
selenium常用的等待有哪些?
python·selenium·测试工具
小白学大数据1 小时前
Python爬虫常见陷阱:Ajax动态生成内容的URL去重与数据拼接
爬虫·python·ajax
2401_841495642 小时前
【计算机视觉】基于复杂环境下的车牌识别
人工智能·python·算法·计算机视觉·去噪·车牌识别·字符识别
Bellafu6662 小时前
selenium定位元素失败,常见错误有哪些?
selenium·测试工具
Adorable老犀牛2 小时前
阿里云-ECS实例信息统计并发送统计报告到企业微信
python·阿里云·云计算·企业微信
倔强青铜三3 小时前
苦练Python第66天:文件操作终极武器!shutil模块完全指南
人工智能·python·面试
倔强青铜三3 小时前
苦练Python第65天:CPU密集型任务救星!多进程multiprocessing模块实战解析,攻破GIL限制!
人工智能·python·面试
Panda__Panda3 小时前
docker项目打包演示项目(数字排序服务)
运维·javascript·python·docker·容器·c#
Lris-KK3 小时前
力扣Hot100--94.二叉树的中序遍历、144.二叉树的前序遍历、145.二叉树的后序遍历
python·算法·leetcode
2501_915909064 小时前
原生 iOS 开发全流程实战,Swift 技术栈、工程结构、自动化上传与上架发布指南
android·ios·小程序·uni-app·自动化·iphone·swift