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

解决方案:更换定位方式

相关推荐
微风粼粼23 分钟前
程序员在线接单
java·jvm·后端·python·eclipse·tomcat·dubbo
云天徽上38 分钟前
【PaddleOCR】OCR表格识别数据集介绍,包含PubTabNet、好未来表格识别、WTW中文场景表格等数据,持续更新中......
python·ocr·文字识别·表格识别·paddleocr·pp-ocrv5
你怎么知道我是队长1 小时前
python-input内置函数
开发语言·python
XMAIPC_Robot1 小时前
基于ARM+FPGA的光栅尺精密位移加速度测试解决方案
arm开发·人工智能·fpga开发·自动化·边缘计算
叹一曲当时只道是寻常1 小时前
Python实现优雅的目录结构打印工具
python
hbwhmama2 小时前
python高级变量XIII
python
费弗里3 小时前
Python全栈应用开发利器Dash 3.x新版本介绍(3)
python·dash
dme.3 小时前
Javascript之DOM操作
开发语言·javascript·爬虫·python·ecmascript
加油吧zkf3 小时前
AI大模型如何重塑软件开发流程?——结合目标检测的深度实践与代码示例
开发语言·图像处理·人工智能·python·yolo
t_hj3 小时前
python规划
python