- VisualStudio2022插件的安装及使用-编程手把手系列文章
- pprof-在现网场景怎么用
- C#实现的下拉多选框,下拉多选树,多级节点
- 【学习笔记】基础数据结构:猫树
name属性为表单中客户端提交数据的标识,一个网页中name值可能不是唯一的。所以要根据实际情况进行判断 。
。
import time from selenium import webdriver from selenium.webdriver.common.by import By # 指定浏览器的位置,解决浏览器驱动和浏览器版本不匹配的问题 chrome_location = r'D:\pythonProject2023\SeleniumFirst\chrome-win64\chrome.exe' options = webdriver.ChromeOptions() options.binary_location = chrome_location driver = webdriver.Chrome(options=options) driver.get('https://www.baidu.com') # 只获取属性的第一个元素 driver.find_element(By.NAME, 'wd').send_keys("万笑佛博客园") # 获取属性的所有元素 driver.find_elements(By.NAME, 'wd')[0].send_keys("万笑佛博客园") time.sleep(3)
5-通过链接文本定位,By.LINK_TEXT 和通过链接部分文本定位,By.PARTIAL_LINK_TEXT 。
使用链接的全部文字定位元素 。
import time from selenium import webdriver from selenium.webdriver.common.by import By # 指定浏览器的位置,解决浏览器驱动和浏览器版本不匹配的问题 chrome_location = r'D:\pythonProject2023\SeleniumFirst\chrome-win64\chrome.exe' options = webdriver.ChromeOptions() options.binary_location = chrome_location driver = webdriver.Chrome(options=options) driver.get('https://www.baidu.com') driver.find_element(By.LINK_TEXT, '新闻').click() #部分包含 #driver.find_element(By.PARTIAL_LINK_TEXT, '闻').click() time.sleep(3)
。
当一个元素无法直接定位,也就是没有id,name等确定标识,这个时候我们需要考虑使用css selector定位器.
它是一种通过CSS样式选择器来定位元素的方法 。
CSS常用汇总 。
。
import time from selenium import webdriver from selenium.webdriver.common.by import By # 指定浏览器的位置,解决浏览器驱动和浏览器版本不匹配的问题 chrome_location = r'D:\pythonProject2023\SeleniumFirst\chrome-win64\chrome.exe' options = webdriver.ChromeOptions() options.binary_location = chrome_location driver = webdriver.Chrome(options=options) driver.get('https://www.baidu.com') #使用id属性定位,id前面要加#号 driver.find_element(By.CSS_SELECTOR, '#kw').send_keys("万笑佛博客园") #通过class属性定位,class前面要加. driver.get('https://www.bilibili.com') driver.find_element(By.CSS_SELECTOR, '.nav-search-input').send_keys('万笑佛博客园') # 根据name属性定位,属性值为[name="wd"] driver.get('https://www.baidu.com') driver.find_element(By.CSS_SELECTOR, '[name="wd"]').send_keys("万笑佛博客园") # 根据标签属性定位 driver.get('https://www.baidu.com') driver.find_element(By.CSS_SELECTOR, 'a[href="http://image.baidu.com/"]').click() # 模糊匹配-包含 driver.find_element(By.CSS_SELECTOR, 'a[href*="image.baidu.com"]').click() # 模糊匹配-匹配开头 driver.find_element(By.CSS_SELECTOR, 'a[href^="http://image.baidu"]').click() # 模糊匹配-匹配结尾 driver.find_element(By.CSS_SELECTOR, 'a[href$="image.baidu.com/"]').click() # 组合定位 driver.get('https://www.baidu.com') # input+name driver.find_element(By.CSS_SELECTOR, 'input[name="wd"]').send_keys("万笑佛博客园") # input+class driver.find_element(By.CSS_SELECTOR, 'input.s_ipt').send_keys("万笑佛博客园") # 一般根据最近一个id属性往下找,可以根据class或者标签。 #s-top-left > a #:nth-child(3)代表第几个子元素,下标从1开始 driver.get('https://www.baidu.com') # 百度首页新闻,以下三种方式皆可 driver.find_element(By.CSS_SELECTOR, 'div.s-top-left-new.s-isindex-wrap a' ) # 根据class driver.find_element(By.CSS_SELECTOR, 'div#s-top-left a') # 根据id driver.find_element(By.CSS_SELECTOR, '#s-top-left a') # 简写 # 百度首页地图,以下2种方式皆可 driver.find_element(By.CSS_SELECTOR, '#s-top-left a:nth-child(3)') driver.find_elements(By.CSS_SELECTOR, '#s-top-left a')[2] # a:first-child 第一个标签 driver.find_element(By.CSS_SELECTOR, '#s-top-left a:first-child') # a:last-child 最后一个标签 driver.find_element(By.CSS_SELECTOR, '#s-top-left a:last-child') time.sleep(3)
。
。
。
。
。
。
最后此篇关于Selenium4自动化测试3--元素定位By.NAME,By.LINK_TEXT和通过链接部分文本定位,By.PARTIAL_LINK_TEXT,css_selector定位,By.CSS_SELECTOR的文章就讲到这里了,如果你想了解更多关于Selenium4自动化测试3--元素定位By.NAME,By.LINK_TEXT和通过链接部分文本定位,By.PARTIAL_LINK_TEXT,css_selector定位,By.CSS_SELECTOR的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我有一堆字符串,其中包含以姓氏,名字格式命名的名称列表,并用逗号分隔,如下所示: names 序列化字符串中的“first name last name”,我们在Stack Overflow上找到一个
在尝试合并多个数据框时,我得到了一些非常奇怪的东西。帮助! 我需要通过“RID”和“VISCODE”列合并一堆数据框。这是它的外观示例: d1 = data.frame(ID = sample(9,
让我们尽可能简单地做第一个例子。 我想知道如何应用这个宏;像这里适用于例如printf("%s",macro(arg)); #include #include #include #define
以下2个bean声明之间有什么区别吗? @Bean(name = "bean1") public A getA() { return new A(); } @Bean @Quali
if(c.get_name(&name) && name && !strcmp(name, contName)) 谁能告诉我这行代码在 C++ 中的含义 最佳答案 如果 c 有一个名字并且它等于 co
我是 Rails 的初学者,在改进我的搜索查询时遇到了一些问题: 在我调用的 Controller 中: def index if params[:search] @persons = Pers
谁能帮我解决这段代码的最后一部分的编译错误它的说法创建构造函数请帮助 public class Officer { public static void main(String args[]
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 8 年前。 Improve t
我创建了一个 Web 应用程序,它具有使用 JSF 技术的 createBook.xhtml 并且它使用托管 Bean。在此页面中,用户必须在输入字段中填写所需信息,然后点击提交按钮。然后应使用 do
嘿,我正在尝试弄清楚如何将在 mySQL 中工作的语句转换为 PostgreSQL 并且很好奇是否有人知道解决方案。 这是在 mySQL 中有效的语句: def self.by_name(keywor
如果我要创建所有类型的类型,而不是使用字符串和原始类型,那么最大的缺点是什么? 通常它看起来像: String name = person.getName(); int age = person.ge
我正在尝试从以下内容中提取郊区名称: 12 street name, suburb name, CTG 1234 在 PHP 中使用正则表达式。 街道和郊区名称都可以是任意数量的单词长度。 CTG 是
我有一个呈现个人详细信息组件的父组件,并且正在注入(inject)父组件的验证器范围。如果我使用 v-validate 指令和 this.$validator.validateAll() 或 this
现在,据我了解,name[] 声明中的 extern 告诉编译器它的定义在其他地方(在我的程序中,我定义了它低于我使用它的部分)。但是为什么 strlen() 和 sizeof 会有不同的结果?str
我一直在解决一个问题: "Design a program that asks the user for a series of names (in no particular order). Aft
我的 XML 如下所示: 我想使用 JAXB 来阅读该内容。 我知道我能做到 @XmlRootElement(name="thing") public class Thing{
对于字符串 name[],我们可以使用 strlen(name)+1 和 sizeof(name) 互换 在我们的代码中没有经过深思熟虑?他们不一样吗?我检查了一下,发现两者的返回类型都是相同的,si
我正在尝试从以下内容中提取郊区名称: 12 street name, suburb name, CTG 1234 在 PHP 中使用正则表达式。 街道和郊区名称的长度可以是任意数量。 CTG 是 st
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 8 年前。 Improve t
bash 手册列出了 for 的语法。复合语句为for name [ [ in [ word ... ] ] ; ] do list ; done这意味着 do 之前的分号如果 in 是可选的子句省略
我是一名优秀的程序员,十分优秀!