Pycharm selenium简单demo及底层代码逻辑实现示例

本文通过一个简单的Selenium Python demo,逐步解析其底层代码实现,包括 webdriver.Chrome() 的创建、driver.get() 的URL访问、find_element_by_方法的元素定位、send_keys() 的文本输入以及click()的点击操作。通过源码跟踪,展示了如何将高层接口转化为底层执行命令,帮助读者深入理解Selenium的工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 先来一个selenium简单demo

import time
from selenium import webdriver

# 创建一个webdriver对象
driver = webdriver.Chrome()
# 如果chrome不是安装在默认路径,则要driver = webdriver(executable_path='chrome.exe的指定路径')

# 访问指定url
driver.get('http://www.baidu.com')
# 找到搜索输入框
el = driver.find_element_by_name('wd')
# el = driver.find_element("id", 'kw')
# el = driver.find_element_by_id('kw')

# 对元素进行输入文本的操作
# time.sleep(3)
el.send_keys('F12打开开发者工具')
# 找到搜索按钮,并点击一次
driver.find_element_by_id('su').click()
# 等待
time.sleep(3)
# 关闭浏览器并释放后台进程,不关闭的话,每运行一次,会创建一个webdriver对象在后台进程
driver.quit()

简单定位元素

el = driver.find_element("name",'wd')
el = driver.find_element("id", 'kw')

这两句代码实现定位元素的效果,打开开发者工具->查看器,点击要定位的位置,这里又有id又有name,所以可以通过name或id定位到这个搜索框。
定位元素

上面就不解释了,我这篇主要记录怎么看底层代码,主要是下面的内容。

2 底层代码实现示例

第一句

driver = webdriver.Chrome()

按住ctrl,然后点击函数Chrome,进入Chrome()的实现代码,如下图
在这里插入图片描述所以实际上这句代码是这样的:

driver = WebDriver(executable_path="chromedriver")

还要加导入:

from selenium.webdriver.chrome.webdriver import WebDriver

第二句

driver.get('http://www.baidu.com')

按住ctrl,点击get,到了这个方法的实现代码,如下图:
在这里插入图片描述所以实际上这句代码是这样的:

driver.execute(Command.GET, {'url': 'http://www.baidu.com'})
import选择

Command.GET下面会有红曲线,找不到这个东西,会发现需要导入,导入出现很多选择,如下图,怎么知道导入哪个?
在这里插入图片描述右击打开的源代码文件,点击copy path,会出现该py文件的路径窗口,所以就知道实际应该import哪个了
在这里插入图片描述

from selenium.webdriver.chrome.webdriver import WebDriver

继续上面的,我们走到了

driver.execute(Command.GET, {'url': 'http://www.baidu.com'})

又可以按住ctrl,点击Command,又会出现下图,发现Command.GET实际上就是"get",所以又可以变成这句:

driver.execute("get", {'url': 'http://www.baidu.com'})

在这里插入图片描述

第三句

el = driver.find_element_by_name('wd')

按住ctrl,点击find_element_by_name,到了下图:
在这里插入图片描述所以这句可以变成

from selenium.webdriver.common.by import By
el = driver.find_element(by=By.NAME, value='wd')

再变成

el = driver.find_element("name", 'wd')

在这里插入图片描述

第四句

el.send_keys('F12打开开发者工具')

按住ctrl,点击send_keys
在这里插入图片描述

el._execute("sendKeysToElement",
                      {'text': "".join(keys_to_typing('F12打开开发者工具')),
                       'value': keys_to_typing('F12打开开发者工具')})

第五句

driver.find_element_by_id('su').click()

与第三句一样的步骤,先变成

driver.find_element("id",'su').click()

再按住ctrl,点击click()
在这里插入图片描述

driver.find_element("id",'su')._execute(Command.CLICK_ELEMENT)

再变成

driver.find_element("id",'su')._execute("clickElement")

最终代码:

包含了转换的过程。

import time
from selenium import webdriver

# 创建一个webdriver对象
# driver = webdriver.Chrome()
from selenium.webdriver.chrome.webdriver import WebDriver
from selenium.webdriver.common.utils import keys_to_typing
from selenium.webdriver.remote.command import Command

driver = WebDriver(executable_path="chromedriver")
# 如果chrome不是安装在默认路径,则要driver = webdriver(executable_path='chrome.exe的指定路径')

# 访问指定url
# driver.get('http://www.baidu.com')
# driver.execute(Command.GET, {'url': 'http://www.baidu.com'})
driver.execute("get", {'url': 'http://www.baidu.com'})

# 找到搜索输入框
# el = driver.find_element_by_name('wd')
# el = driver.find_element(by=By.NAME, value='wd')
el = driver.find_element("name", 'wd')

# 对元素进行输入文本的操作
time.sleep(3)
# el.send_keys('F12打开开发者工具')
el._execute("sendKeysToElement",
                      {'text': "".join(keys_to_typing('F12打开开发者工具')),
                       'value': keys_to_typing('F12打开开发者工具')})
# 找到搜索按钮,并点击一次
# driver.find_element_by_id('su').click()
# driver.find_element("id",'su').click()
# driver.find_element("id",'su')._execute(Command.CLICK_ELEMENT)
driver.find_element("id",'su')._execute("clickElement")
# 等待
time.sleep(10)
# 关闭浏览器并释放后台进程,不关闭的话,每运行一次,会创建一个webdriver对象在后台进程
# driver.quit()
driver.service.stop()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值