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

解决方案:更换定位方式

相关推荐
2401_8414956438 分钟前
【自然语言处理】生成式语言模型GPT复现详细技术方案
人工智能·python·gpt·深度学习·语言模型·自然语言处理·transformer
snakecy1 小时前
过关斩将编程题
开发语言·python
Blossom.1181 小时前
大模型在边缘计算中的部署挑战与优化策略
人工智能·python·算法·机器学习·边缘计算·pygame·tornado
diannao7201 小时前
实时将大模型的解决方案转换为随机应变的机器人指令
开发语言·windows·python·机器人
麦烤楽鸡翅2 小时前
挡住洪水 (牛客)
java·数据结构·c++·python·算法·bfs·牛客
用户3721574261352 小时前
如何使用Python高效转换Excel到HTML
python
ashuicoder2 小时前
Python 函数传参与 JavaScript 对比
python
kyle-fang2 小时前
pytorch-张量
人工智能·pytorch·python
PKNLP3 小时前
11.大模型Agent应用
python·agent·pip
woshihonghonga3 小时前
Dropout提升模型泛化能力【动手学深度学习:PyTorch版 4.6 暂退法】
人工智能·pytorch·python·深度学习·机器学习