掌握元素定位

首先,最重要的一条就是禁止手动输入,必须复制粘贴,必须!!!

根据元素的一个特征来定位,6种。

id: 元素的id属性。- 唯一。

class: 元素的class属性

tag: 元素的标签名

name: 元素的name属性

针对a元素:

link_text: 针对a元素的文本内容 - 完全匹配

partial_link_text: 针对a元素的文本内容 - 包含

组合元素的多种特征/关系 ,来定位。2种 - 万能定位。

xpath

css selector: css选择器

相对定位:以双斜杠开头//

相对路径:相对参照物。//相对于前面节点,如果//在表达式开头则表示相对整个html。

定位原则:

1、不依靠节点顺序和节点位置

2、只要能够找得到匹配特征的元素就可以。

定位辅助工具:

F12->elements->Ctrl+F

相对定位表达式(重点!常用!优先考虑!的方法):

1、//标签名[@属性名=值]

2、//标签名[text()=值]

3、//标签名[contains(@属性名,值)]           //标签名[contains(text(),值)]

4、*标签名或者属性名都可以用*表示匹配所有       //*[contains(@*,"TopiDiscuss")] 

单单一属性,无法唯一定位到元素

可以组合

逻辑:and  、  or

//标签名[text()=值 and  @属性名=值  and  contains(@属性名,值)]

//标签名[text()=值 or  @属性名=值  or  contains(@属性名,值)]

仅仅依靠元素本身的特征,已经无法唯一定位。

层级:

//祖先节点//要找的节点

//div[@id="u1"]//a[@name="tj-login"]

轴定位:

元素的兄弟姐妹、父母祖先

轴运算:

ancestor:祖先节点,包括父节点

parent:父节点

定位的某个节点/轴名称::节点

定位id=form的form节点中 子元素中name=issp的input标签

//form[@id='form']/child::input[@name='issp']

定位id=form的form节点中 祖先元素中id='wrapper的div标签

//form[@id='form']/ancestor::div[@id='wrapper']



preceding:当前元素节点标签之前的所有节点(按照html页面先后顺序)

preceding-sibling:当前元素节点标签之前的所有兄弟节点

following:当前元素节点标签之后的所有节点(按照html页面先后顺序)

following-sibling:当前元素节点标签之后的所有兄弟节点

另外一种解释:

parent::div 上层父节点,你那叫div的亲生爸爸,最多有一个;

child::div 下层所有子节点,你的所有亲儿子中叫div的;

ancestor::div 上面所有直系节点,是你亲生爸爸或者你亲爹或者你亲爹的爸爸中叫div的;

descendant::div 下面所有节点,你的后代中叫div的,不包括你弟弟的后代;

following::div 自你以下页面中所有节点叫div的;

following-sibling::div 同层下节点,你所有的亲弟弟中叫div的;

preceding::div 同层上节点,你所有的亲哥哥以及他们的后代中叫div的;

preceding-sibling::div 同层上节点,你所有的亲哥哥中叫div的;


代码示例:

from timeimport sleep

# 引入第三方库

from seleniumimport webdriver

# 打开浏览器 - 指令1 - 开启与浏览器之间的会话。

driver = webdriver.Chrome()

# 最大化窗口

driver.maximize_window()

# 访问百度首页 - 指令2

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

# 合并写法

driver.find_element_by_id("kw").send_keys("selenium webdriver")

# class

ele = driver.find_element_by_class_name("s_ipt")# 只支持一个class值

eles = driver.find_elements_by_class_name("s_ipt")

# tag_name

driver.find_element_by_tag_name("input")

driver.find_elements_by_tag_name("input")

# name

driver.find_element_by_name("wd")

driver.find_elements_by_name("wd")

# link_text  partial_link_text

driver.find_element_by_link_text("hao123")

driver.find_elements_by_link_text("hao123")

driver.find_element_by_partial_link_text("123")

driver.find_elements_by_partial_link_text("123")

sleep(7)

# 关闭当前窗口。

driver.close()

# 关闭浏览器,关闭会话。

driver.quit()

xpath表达式

driver.find_element_by_xpath('//div[@id="u1"]//a[@name="tj_login"]').click()

css定位

driver.find_element_by_css_selector('div#u1 a[name="tj_login"]').click()

# 找到登陆按钮,并点击,弹出登陆窗口

loc = (By.XPATH,'//div[@id="u1"]//a[@name="tj_login"]')

driver.find_element(*loc).click()

# 元素表达

loc = (By.ID,'TANGRAM__PSP_11__footerULoginBtn')

# 等待 - 等待元素可见。

wait.until(EC.visibility_of_element_located(loc))

# 在登陆的窗口当中,点击  用户名登陆

driver.save_screenshot("登陆窗口.png")# 截图

driver.find_element(*loc).click()

# 等待用户名输入框可见,然后输入用户名

loc = (By.ID,"TANGRAM__PSP_11__userName")

ele = wait.until(EC.visibility_of_element_located(loc))

print("等待元素可见的返回对象是:",ele)

driver.find_element(*loc).send_keys("123456789")

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351