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

目录

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

命令:

python 复制代码
pip show selenium

结果:

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

2、根据提示重启内核

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

提示:Note: you may need to restart the kernel to use updated packages.

我:fine~~,你提示就提示吧,我能拿你怎么办呢!!!

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

python 复制代码
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提示:

bash 复制代码
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、根据id找到元素,进行操作

python 复制代码
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')

或者是:

python 复制代码
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时),最重要也是最难的就是定位元素,定位到元素之后,就可以进行"获取元素的数据"、"输入数据"、"点击"等操作了。

相关推荐
天才测试猿17 分钟前
Selenium工作原理详解
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
先知-旭日东升2 小时前
VSCode中操作gitee
ide·vscode·gitee
守城小轩5 小时前
在Selenium 中更改 User-Agent 的步骤与最佳实践
chrome·selenium·自动化·网络爬虫·浏览器开发·浏览器爬虫
背着代码的蜗牛12 小时前
Pycharm远程开发注意事项
ide·python·pycharm·ssh·远程工作
selfsuer14 小时前
统信UOS中使用Vscode编程
ide·vscode·编辑器
Q_w774214 小时前
配置 VSCode 的 C# 开发环境
ide·vscode·c#
cpp加油站15 小时前
无需qt-creator,使用Trae从0到1生成qt的开发、构建、调试环境
开发语言·ide·qt
zzhz92516 小时前
selenium(鼠标操作、页面操作、用例设计)
selenium·测试工具
J不知道ava19 小时前
在idea里开发第一个Servlet
java·ide·intellij-idea
程序员杰哥19 小时前
python+requests实现的接口自动化测试
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例