Python + Selenium —— 网页元素定位之name 定位!

1213 篇文章 11 订阅
682 篇文章 3 订阅

HTML 中的 name 属性,主要存在与 From 表单中。

表单在网页中主要负责数据采集功能并将数据提交给服务器。一个表单有三个基本组成部分:

  1. 表单标签:这里面包含了处理表单数据的接口地址以及数据提交到服务器的请求方法(GET,POST);

  2. 表单域:包含了文本框、密码框、隐藏域、多行文本框、复选框、单选框、下拉选择框和文件上传框等;

  3. 表单按钮:包括提交按钮、复位按钮和一般按钮;用于将数据传送到服务器对应的接口或者取消输入,还可以用表单按钮来控制其他定义了处理脚本的处理工作。

我们看一个表单例子,这是一个简书的登录表单:

上面的登录表单包含了:

  • 表单标签:

    • 登录的接口地址/sessions

    • 请求的方法post

  • 表单域

    • 账号输入框

    • 密码输入框

    • 记住我复选框

  • 表单按钮

    • 登录按钮

而 name 属性就出现在表单域和表单按钮的元素属性中,比如账号输入框中,其 name 属性为name="session[email_or_mobile_number]"。这些 name 属性用来告诉服务器,发送的表单数据中每个字段的含义。

看一个命名更直观点的:


name 属性就是为了让服务器上的处理程序明白表单传送的数据中每个字段的含义。

现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:691998057【暗号:csdn999】

我们实际测试工作中,很多后台数据提交都是通过表单提交,这些表单中的元素都会用到 name 属性。比如下面这种电商后台添加商品的表单。

来,补全一下简书的模拟登录(如果你没有账号,只要能在账号和密码框输入内容即可)代码:

from selenium import webdriver
driver = webdriver.Chrome()
driver.get("https://www.jianshu.com/sign_in")
driver.find_element_by_name("session[email_or_mobile_number]").send_keys("小满测试")
# 输入密码
# 点击登录按钮,注意按钮没有name属性,选个其他的属性

检验唯一性

谈到 name 的时候,name 由于页面上多表单的存在,可能 name 就不那么唯一了。当然绝大部分情况下,name 都是唯一的。

如果偶然遇到不唯一的情况,也就是通过 name 能找到多个的话,WebDriver 会返会找到的第一个元素。当然这第一个是不是你想要的就不好说了。

好办!我们可以在开发者工具中检查一下是否唯一,或者不唯一的话,第一个是不是我们想要的呢?

在开发者工具中有一个功能叫做console,是一个 JavaScript 调试器。可以在这里输入 js 代码。我们可以通过 js 中的一些方法来验证唯一性:


将前面拷贝到的 name 属性值,调用document.getElementsByName()检查,该函数会返回一个数组,如果数组中只有一个元素,那么我们的 name 值是唯一的。

document.getElementsByName('session[email_or_mobile_number]')

运行后,点开下面的 Nodelist,查看找到的元素是否是你需要的:

以后呢,你在写代码前,对于一些拿不准的语句,都可以在这里先去验证一下,再写到你的代码中去,可以有效的减少出错和调试浪费的时间。

下面是配套资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

最后: 可以在公众号:程序员小濠 ! 免费领取一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!

  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用 PythonSelenium 库进行元素定位时,可以创建一个类来管理定位相关的操作。下面是一个示例代码: ```python from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC class ElementLocator: def __init__(self, driver): self.driver = driver def find_element_by_id(self, element_id): return self.driver.find_element(By.ID, element_id) def find_element_by_xpath(self, xpath): return self.driver.find_element(By.XPATH, xpath) def wait_for_element_visible(self, locator, timeout=10): return WebDriverWait(self.driver, timeout).until(EC.visibility_of_element_located(locator)) # 可以添加其他常用的元素定位方法,比如 find_element_by_css_selector、find_element_by_class_name 等等 # 示例用法 driver = webdriver.Chrome() element_locator = ElementLocator(driver) element = element_locator.find_element_by_id("element_id") element.click() visible_element = element_locator.wait_for_element_visible((By.XPATH, "//div[@class='my-element']")) ``` 在上面的示例代码中,我们创建了一个名为 `ElementLocator` 的类,它接收一个 Selenium WebDriver 对象作为参数,并提供了一些常用的元素定位方法,比如 `find_element_by_id` 和 `find_element_by_xpath`。此外,还添加了一个 `wait_for_element_visible` 方法,用于等待元素可见。 你可以根据自己的需要扩展 `ElementLocator` 类,添加其他常用的元素定位方法,以便于在测试或爬虫等场景中使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值