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

解决方案:更换定位方式

相关推荐
江沉晚呤时3 小时前
在 C# 中调用 Python 脚本:实现跨语言功能集成
python·microsoft·c#·.net·.netcore·.net core
电脑能手4 小时前
如何远程访问在WSL运行的Jupyter Notebook
ide·python·jupyter
Edward-tan4 小时前
CCPD 车牌数据集提取标注,并转为标准 YOLO 格式
python
老胖闲聊5 小时前
Python I/O 库【输入输出】全面详解
开发语言·python
倔强青铜三5 小时前
苦练Python第18天:Python异常处理锦囊
人工智能·python·面试
倔强青铜三5 小时前
苦练Python第17天:你必须掌握的Python内置函数
人工智能·python·面试
迷路爸爸1805 小时前
让 VSCode 调试器像 PyCharm 一样显示 Tensor Shape、变量形状、变量长度、维度信息
ide·vscode·python·pycharm·debug·调试
王者鳜錸6 小时前
使用Selenium自动化获取抖音创作者平台视频数据
selenium·自动化·音视频
咸鱼鲸6 小时前
【PyTorch】PyTorch中的数据预处理操作
人工智能·pytorch·python
Dxy12393102166 小时前
Python ExcelWriter详解:从基础到高级的完整指南
开发语言·python