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

练习用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.kler.cn/a/599102.html

相关文章:

  • 机器臂运动控制算法工程师面试
  • matrix-breakout-2-morpheus靶机攻略
  • 使用Python将视频转化为gif
  • AI 如何重塑数据湖的未来
  • android 接入google 登录
  • 事务的四大特性(ACID)详解
  • 同旺科技USB to SPI 适配器 ---- 多适配器、多从机混合调试
  • AI安全 | 利用链式思维推理劫持 LRM
  • Vue3中SuspensedefineAsyncComponent异步组件的应用场景。
  • 深度学习优化技术教程
  • CSRF SSRF RCE
  • 卷积神经网络 - 参数学习
  • 服务器中防火墙的重要性
  • 【QA】Qt中直接渲染和离屏渲染有什么区别
  • 爬虫入门re+bs4
  • 构建高效的LinkedIn图像爬取工具
  • 《Operating System Concepts》阅读笔记:p460-p4470
  • stc8g1k08a+cd4017红绿灯
  • Linux 文件操作-文件IO函数2- write向文件写入数据、read从文件读取数据、lseek重定位文件描述符的偏移量的验证
  • (UI自动化测试web端)第二篇:元素定位的方法_xpath路径定位