2022-06-28

一、selenium定位方法

1、WebDriver8种基本元素定位方式

1)find_element_by_id() 根据id属性进行定位

2)find_element_by_name() 根据name元素进行定位

3)find_element_by_class_name() 根据class的名字进行定位

4)find_element_by_xpath() xpath是XML路径语言,它可以用来确定xml文档中的元素位置,通过元素的路径来完成对元素的查找

5)find_element_by_css_selector() CSS属性定位可以比较灵活地选择控件的任意属性,定位方式也会比xpath快

6)find_element_by_tag_name() 根据标签名进行定位

7)find_element_by_link_text() 根据完整的超链接文字进行定位

8)find_element_by_partial_link_text() 根据部分超链接文字进行定位

2、By定位

by定位需要需要导入By类:from selenium.webdriver.common.by import By

find_element(By.ID,"")

find_element(By.NAME,"")

find_element(By.CLASS_NAME,"")

find_element(By.TAG_NAME,"")

find_element(By.LINK_TEXT,u" ")

find_element(By.PARTIAL_LINK_TEXT,u" ")

find_element(By.XPATH,"")

find_element(By.CSS_SELECTOR,"")

3、elements复数定位

八种基础的定位方法都有对应的复数形式

id复数定位find_elements_by_id()

name复数定位find_elements_by_name()

class复数定位find_elements_by_class_name()

tag复数定位find_elements_by_tag_name()

link复数定位find_elements_by_link_text()

partial_link复数定位find_elements_by_partial_link_text()

xpath复数定位find_elements_by_xpath()

css复数定位find_elements_by_css_selector()

4、JS的5种定位方式

id定位:document.getElementById()

name定位:document.getElementsByName()

tag定位:document.getElementsByTagName()

class定位:document.getElementsByClassName()

css定位:document.querySelectorAll()

二、其他selenium操作

1、常用库导入

1)from selenium import webdriver 导入webdriver模块

2)from selenium.webdriver import ActionChains 导入动作链类,动作链可以储存鼠标的动作,并一起执行

3)from selenium.webdriver.common.key import Key 键盘操作使用的是Keys类,一般配合send_keys使用

4)from selenium.webdriver.support.select import Select 下拉框的操作都交由Select类进行处理

5)from selenium.webdriver.common.by import By

from selenium.webdriver.support.ui import WebDriverWait

from selenium.webdriver.support import expected_conditions as EC 显示等待使用的类

2、基本操作

1)浏览器相关操作

创建浏览器对象  driver = webdriver.xxx()

窗口最大化    maximize_window()

获取浏览器尺寸  get_window_size()

设置浏览器尺寸  set_window_size()

获取浏览器位置  get_window_position()

设置浏览器位置  set_window_position(x,y)

关闭当前标签/窗口 close()

关闭所有标签/窗口  quit()

2)页面相关操作

请求某个url      driver.get(url)

刷新页面操作     refresh()

回退到之前的页面   back()

前进到之后的页面   forward()

获取当前访问页面url  current_url

获取当前浏览器标题  title

保存图片       get_screenshot_as_png()/get_screenshot_as_file(file)

网页源码       page_source

3、元素的操作

点击操作    element.click()

清空输入框   element.clear()

输入框输入数据 element.send_keys(data)

获取文本内容(既开闭标签之间的内容)  element.text

获取属性值(获取element元素的value属性的值)  element.get_attribute(value)

4、鼠标和键盘操作

鼠标操作需要导入类,见第一部分,然后创建对象ActionChains(driver),键盘操作导入类

鼠标右击

el = driver.find_element_by_xxx(value)

context_click(el)

鼠标双击

el = driver.find_element_by_xxx(value)

ActionChains(driver).double_click(el).perform()

鼠标悬停

el = driver.find_element_by_xxx(value)

ActionChains(driver).move_to_element(el).perform()

常用键盘操作

send_keys(Keys.BACK_SPACE) 删除键(BackSpace)

send_keys(Keys.SPACE) 空格键(Space)

send_keys(Keys.TAB) 制表键(Tab)

send_keys(Keys.ESCAPE) 回退键(Esc)

send_keys(Keys.ENTER) 回车键(Enter)

send_keys(Keys.CONTROL,‘a’) 全选(Ctrl+A)

send_keys(Keys.CONTROL,‘c’) 复制(Ctrl+C)

send_keys(Keys.CONTROL,‘x’) 剪切(Ctrl+X)

send_keys(Keys.CONTROL,‘v’) 粘贴(Ctrl+V)

5、弹出框操作

进入到弹出框中  driver.switch_to.alert()

接收警告     accept()

关闭警告     dismiss()

发送文本到警告框 send_keys(data)

6、下拉框操作

将定位到的下拉框元素传入Select类中  selobj = Select(element)

通过索引选择,index 索引从 0 开始  select_by_index()

通过值选择(option标签的一个属性值)  select_by_value()

通过文本选择(下拉框的值)  select_by_visible_text()

查看所有已选  all_selected_options

查看第一个已选  first_selected_option

查看是否是多选  is_multiple

查看选项元素列表  options

取消选择   deselect_by_index() /deselect_by_value()/ deselect_by_visible_text()

7、滚动条操作

js = "window.scrollTo(x,y) " x为水平拖动距离,y为垂直拖动举例

driver.execute_script(js)

js= “var q=document.documentElement.scrollTop=n” n为从顶部往下移动滚动举例

driver.execute_script(js)

8、cookies操作

获取所有cookies  get_cookies()

获取key对应的值  get_cookie(key)

设置cookies  add_cookie(cookie_dict)

删除指定名称的cookie  delete_cookie(name)

删除所有cookie  delete_all_cookies()

9、多标签/多窗口、多表单/多框架切换

多表单/多框架切换

直接使用id值切换进表单   driver.switch_to.frame(value)

定位到表单元素,再切换进入

el = driver.find_element_by_xxx(value)

driver.switch_to.frame(el)

跳回最外层的页面  driver.switch_to.default_content()

跳回上层的页面  driver.switch_to.parent_frame()

多标签/多窗口之间的切换

获取所有窗口的句柄   handles = driver.window_handlers

通过窗口的句柄进入的窗口  driver.switch_to.window(handles[n])

接口测试工具可以使用国产接口测试和接口文档生成工具:apipost


以https://daohang.qq.com/?fr=hmpage 网址为例


一.基本的定位方式

1.ID

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_id("smart_input").send_keys("TEST")

2.Name

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_name("query").send_keys("TEST")

3.ClassName

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_class_name("usersearch").send_keys("Test")

4.LinkTest

以“人民网”这个link举例

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_link_text(u"人民网").click() python2 中文前面加U

二.XPATH定位

1.Xpath标签

还是以这个搜索框为例

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_xpath("//input[@id='smart_input']").send_keys("TEST")

2.Xpath层级

 父级元素定位:如图该搜索栏的父级元素为searchForm,而我们所要定位的所属栏为该父级元素下面第一个input

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_xpath("//form[@id='searchForm']/input[1]").send_keys("TEST")

driver.implicitly_wait(20)

弟弟级定位哥哥元素:

哥哥

弟弟

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_xpath("//input[@name='hdq']/preceding-sibling::input[1]").send_keys("TEST")

driver.implicitly_wait(20)

弟弟找完哥哥,但哥哥怎么去找哥哥嘞?


4哥哥

弟弟

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_xpath("//span[@class='add-bubble']/following-sibling::span[1]").click()

3.Xpath-contains

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_xpath("//input[contains(@id,'smart_input')]").send_keys("TEST")

三.CSS定位(*强烈推荐)

1.CSS-id

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_css_selector("#smart_input").send_keys("TEST")

driver.implicitly_wait(20)

2.CSS-class

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_css_selector(".usersearch").send_keys("TEST")

driver.implicitly_wait(20)

3.CSS-其他

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_css_selector("input[id='smart_input']").send_keys("TEST")

4.CSS-层级

子元素

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_css_selector("#searchForm>#smart_input").send_keys("TEST")

后代元素

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_css_selector("#searchForm #smart_input").send_keys("TEST") #searchForm  #smart_input 中间空格

nth-child的使用(从字面解释就是第几个孩子)

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_css_selector("#searchForm>input:nth-child(1)").send_keys("TEST")在searForm元素下的第一个input标签

first-child的使用

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_css_selector("#searchForm>input:first-child").send_keys("TEST")

last-child的使用



以搜索按钮为例

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

driver.find_element_by_css_selector("#searchForm>input:first-child").send_keys("TEST")

driver.find_element_by_css_selector("#searchForm>input:last-child").click() #点击搜索按钮

四.Jquery定位

1.Jquery-ID

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

inputTest="$('#smart_input').val('TEST')"

driver.execute_script(inputTest)

2.Jquery-Class

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

inputTest="$('.usersearch').val('TEST')"

driver.execute_script(inputTest)

3.Jquery-Type

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

inputTest="$(':text').val('TEST')"

driver.execute_script(inputTest)

4.Jquery-其他

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

inputTest="$('input[id=smart_input]').val('TEST')"

driver.execute_script(inputTest)

5.Jquery-层级

子元素

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

inputTest="$('#searchForm>#smart_input ').val('TEST')"

driver.execute_script(inputTest)

后代元素

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

inputTest="$('#searchForm #smart_input ').val('TEST')"  #searchForm  #smart_input中间空格

driver.execute_script(inputTest)

选择第N个元素

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

inputTest="$('#searchForm>input:first ').val('TEST')"searchForm父级元素下的第一个input标签

driver.execute_script(inputTest)

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

clickbutton="$('#searchForm>input:last ').click()"searchForm父级元素下的最后一个input标签

driver.execute_script(clickbutton)

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

inputTest="$('#searchForm>input:eq(0)').val('TEST')"eq(0):serachForm父级元素下的第一个input标签,用nth-child(1)也是ok的

driver.execute_script(inputTest)

五.JS定位

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

driver.get("https://daohang.qq.com/?fr=hmpage")

inputTest='document.getElementById("smart_input").value="TEST";'其他获取比如name的话,吧getElementById换成getElementsByName

driver.execute_script(inputTest)

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

推荐阅读更多精彩内容