当前位置: 首页 > news >正文

练习用Jupyter使用selenium【疑问未解决版】

目录

  • 1、打开Jupyter后,检查是否安装了selenium
  • 2、根据提示重启内核
  • 3、【疑问1】我重启了内核之后还是提示这句话
  • 4、执行简单的打开网页的代码【结果又报错-疑问2】
  • 5、使用WebDriver对象选择元素的基本方法
    • (1)根据id找到元素,进行输入文本并回车的操作
    • (2)根据class定位元素,获取显示在界面上的text(文本)内容
    • (3)根据标签(tag)名定位元素
  • 6、使用WebElement对象选择元素的基本方法

1、打开Jupyter后,检查是否安装了selenium

命令:

pip show selenium

结果:
在这里插入图片描述
【在 Jupyter Notebook 中,当你安装或更新了某些 Python 包后,系统会提示你重启内核,这样新的包或更新后的包才能被正确加载并使用。】

2、根据提示重启内核

在这里插入图片描述

3、【疑问1】我重启了内核之后还是提示这句话

提示:Note: you may need to restart the kernel to use updated packages.
我:fine~~,你提示就提示吧,我能拿你怎么办呢!!!

4、执行简单的打开网页的代码【结果又报错-疑问2】

from selenium import webdriver
# from selenium.webdriver.edge.service import Service
# 创建一个WebDriver类型的实例对象,运行浏览器驱动,之后控制浏览器
# wd = webdriver.Edge(service = Service(r'D:\edgedriver_win64\msedgedriver.exe'))
wd = webdriver.Edge()
# 在浏览器中打开某网址页面
wd.get('https://www.baidu.com')

结果:edge浏览器成功打开了百度的网页,但是jupyter提示:

DevTools listening on ws://127.0.0.1:31061/devtools/browser/970d1937-368e-423a-bae8-af59c93a6da0
[6804:19916:0320/162225.845:ERROR:edge_qqbrowser_importer_utils_win.cc(158)] QQBrowser user data path not found.
[20628:17792:0320/162226.091:ERROR:ssl_client_socket_impl.cc(891)] handshake failed; returned -1, SSL error code 1, net_error -101
[20628:17792:0320/162226.150:ERROR:ssl_client_socket_impl.cc(891)] handshake failed; returned -1, SSL error code 1, net_error -101
[0x7FF8A495B840] ANOMALY: meaningless REX prefix used
[0x7FF8A4B5C590] ANOMALY: meaningless REX prefix used
[0x7FF8A4B5E810] ANOMALY: meaningless REX prefix used
[0x7FF8A495B840] ANOMALY: meaningless REX prefix used
[0x7FF8A4B5C590] ANOMALY: meaningless REX prefix used
[0x7FF8A4962E30] ANOMALY: meaningless REX prefix used
[0x7FF8A4B5E810] ANOMALY: meaningless REX prefix used
[0x7FF8A4962E30] ANOMALY: meaningless REX prefix used

【查了一圈也不是很懂为什么会这样,明明我的浏览器版本和驱动器版本已经一样了,show time~】
在这里插入图片描述
Edge浏览器驱动器下载地址:驱动器下载地址
在这里插入图片描述

5、使用WebDriver对象选择元素的基本方法

使用WebDriver对象,通过调用各种find函数,创建WebElement对象。

(1)根据id找到元素,进行输入文本并回车的操作

from selenium import webdriver
from selenium.webdriver.common.by import By
# from selenium.webdriver.edge.service import Service
# wd = webdriver.Edge(service = Service(r'D:\edgedriver_win64\msedgedriver.exe'))# 创建一个WebDriver类型的实例对象,运行浏览器驱动,之后控制浏览器
wd = webdriver.Edge()
# 在浏览器中打开某网址页面
wd.get('https://www.baidu.com')# 创建一个WebElement对象,定位web的某一元素,之后对这个元素进行操作
element = wd.find_element(By.ID,'kw')
# 输入文字并回车
element.send_keys('汪苏泷\n')

或者是:

from selenium import webdriver
from selenium.webdriver.common.by import By
# from selenium.webdriver.edge.service import Service
# wd = webdriver.Edge(service = Service(r'D:\edgedriver_win64\msedgedriver.exe'))# 创建一个WebDriver类型的实例对象,运行浏览器驱动,之后控制浏览器
wd = webdriver.Edge()
# 在浏览器中打开某网址页面
wd.get('https://www.baidu.com')# 创建一个WebElement对象,定位web的某一元素,之后对这个元素进行操作
element = wd.find_element(By.ID,'kw')
# 输入文字
element.send_keys('汪苏泷')
# 百度一下
element = wd.find_element(By.ID,'su')
element.click()

在这里插入图片描述
写在最后:
web自动化测试(使用selenium时),最重要也是最难的就是定位元素,定位到元素之后,就可以进行“获取元素的数据”、“输入数据”、“点击”等操作了。

(2)根据class定位元素,获取显示在界面上的text(文本)内容

from selenium import webdriver
from selenium.webdriver.common.by import By
# from selenium.webdriver.edge.service import Service
# wd = webdriver.Edge(service = Service(r'D:\edgedriver_win64\msedgedriver.exe'))# 创建一个WebDriver类型的实例对象,运行浏览器驱动,之后控制浏览器
wd = webdriver

http://www.mrgr.cn/news/95686.html

相关文章:

  • 【MySQL】基本查询(表的增删查改+聚合函数)
  • PostgreSQL_数据使用与日数据分享
  • 网络层之IP协议
  • Pytorch中的torch.utils.data.Dataset 类
  • 开发中常用的设计模式 用法及注意事项【面试题】
  • Flink启动任务
  • 常考计算机操作系统面试习题(四)
  • 深圳问顶安全科技有限公司asktopsec是做什么的?
  • 3. 轴指令(omron 机器自动化控制器)——>MC_SetOverride
  • Android Token的原理和本地安全存储
  • Unity Animation的其中一种运用方式
  • 知识分享导航
  • Jackson使用ObjectNode对象实现JSON对象数据(一):增、删、改、查
  • 深度学习有哪些算法?
  • 05STM32定时器-01定时器概述
  • AI+金融 应用 使用DeepSeek、Qwen等大模型输入自然语言,得到通达信等行情软件公式代码,导入后使用
  • 01STM32时钟树
  • Spring Boot整合MyBatis
  • Python个人学习笔记(19):模块(正则表达式)
  • 【MySQL】内置函数