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带空格等

解决方案:更换定位方式

相关推荐
冷雨夜中漫步1 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
郝学胜-神的一滴2 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再2 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
喵手3 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
2501_944934734 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
helloworldandy4 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
肖永威5 小时前
macOS环境安装/卸载python实践笔记
笔记·python·macos
TechWJ5 小时前
PyPTO编程范式深度解读:让NPU开发像写Python一样简单
开发语言·python·cann·pypto
枷锁—sha5 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
abluckyboy6 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法