码迷,mamicode.com
首页 > 其他好文 > 详细

如何定位元素

时间:2018-11-01 22:28:50      阅读:268      评论:0      收藏:0      [点我收藏+]

标签:htm   class   实际应用   css_   value   code   tab   情况下   width   

以定位百度输入框为例:

技术分享图片

 

<form id="form" name="f" action="/s" class="fm">
      <span class="bg s_ipt_wr quickdelete-wrap">
           <input id="kw" name="wd" class="s_ipt" value="" maxlength="255" autocomplete="off">
</form>

根据ID定位:find_element_by_id(‘kw‘)

 

根据name定位:find_element_by_name(‘wd‘)

 

根据class定位:find_element_by_class_name(‘s_ipt‘)

 

根据tag定位:find_element_by_tag_name(‘input‘)   

        实际应用中比较少使用tag定位一个元素,一般使用tag来定位一组元素

根据tag定位一组元素:find_elements_by_tag_name(‘input‘)

from selenium import webdriver


dr = webdriver.Firefox()
dr.get("https://www.baidu.com")

inputs = dr.find_elements_by_tag_name(input)
for i in inputs:
    if i.get_attribute(id) == "kw":
        i.send_keys(selenium)

 

技术分享图片

根据文本链接定位:find_element_by_link_text("新闻")

       使用到中文的时候需要在开头声明# -*- coding=utf-8 -*-  或者  #coding=utf-8

根据部分文本链接定位:find_element_by_partial_link_text("新")

 

根据xpath定位:find_element_by_xpath(’input[@id="kw"]‘)

        定位除了id name class以外的唯一元素

        find_element_by_xpath(‘//input[@maxlength="255"]‘)

       根据路径来定位

        find_element_by_xpath("//form[@id=‘form‘ and @class=‘fm‘]/span/input")

        根据绝对路径来定位,但是路径可能改变或元素较深的情况下不推荐

       find_element_by_xpath("/html/body/div/div[2]/div/form/span/input")

 

根据css定位

css选择器的常用语法
选择器 描述
.class class选择器
#id id选择器
* 选择所有元素
element 选择某个元素
element1>element2 选择父元素为1元素的所有2元素
element1+element2 选择紧接着1元素后面的所有2元素
[artibute=value] 选择target等于某个值的所有字

 

 

 

 

 

 

 

 

 

 

 

e.g:

find_element_by_css_selector(‘.s_ipt‘)

find_element_by_css_selector(‘#kw‘)

find_element_by_css_selector(‘form.fm > span > input#kw‘)

find_element_by_css_selector(‘input[maxlength="255"]‘)

 

如何定位元素

标签:htm   class   实际应用   css_   value   code   tab   情况下   width   

原文地址:https://www.cnblogs.com/hlbzzt/p/9891050.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!