主頁 >  其他 > 終于有大佬把軟體測驗的元素定位總結得這么通俗易懂了!

終于有大佬把軟體測驗的元素定位總結得這么通俗易懂了!

2021-07-23 07:01:04 其他

為什么要學習元素定位方式

1. 讓程式操作指定元素,就必須先找到此元素;
2. 程式不像人類用眼睛直接定位到元素;
3. webDriver提供了八種定位元素的方式,

定位方式總結

1. id、 name class_name tag_name :根據元素的標簽或元素的屬性來進行定位
2. link_text、 partial_link_text :根據超鏈接的文本來進行定位( a 標簽)
3. xpath:為元素路徑定位
4. css:為 css 選擇器定位(樣式定位)

1id定位

說明: HTML 規定 id 屬性在整個 HTML 檔案中必須是唯一的, id 定位就是通過元素的 id 屬性來定位元素
前提:元素有 id 屬性
id 定位方法: find_element_by_id()
實作案例 -1 需求:打開論壇登錄界面( http://49.233.108.117:3000/signin ),通過 id 定位,輸入用戶 名和密碼,

2name定位

說明: HTML 規定 name 屬性來指定元素名稱, name 的屬性值在當前檔案中可以不是唯一
的, name 定位就是根據 name 屬性來定位
前提:元素有 name 屬性
name 定位方法: find_element_by_name()
實作案例 -2 需求:打開論壇登錄界面( http://49.233.108.117:3000/signin ),通過 name
位,輸入用戶名和密碼,

3class_name定位

說明: HTML 規定 class 來指定元素的類名, class 定位就是根據 class 屬性來定位, 用法和
name,id 類似,
前提:元素有 class 屬性
class_name 定位方法: find_element_by_class_name()
實作案例 -3 需求:打開論壇登錄界面( http://49.233.108.117:3000/signin ),通過 class
位,輸入用戶名和密碼,并點擊登錄,

4tag_name定位

說明: HTML 本質就是由不同的 tag( 標簽 ) 組成,而每個 tag 都是指同一類,所以 tag 定位效
率低,一般不建議使用; tag_name 定位就是通過標簽名來定位
tag_name 定位方法: find_element_by_tag_name()
實作案例 -4 需求:打開論壇登錄界面( http://49.233.108.117:3000/signin ),通過 tag 定位,
輸入用戶名和密碼,

5link_text定位

說明: link_text 定位于前面 4 個定位有所不同,它專門用來定位超鏈接文本 <a> 文本值
</a>
前提: 定位的元素是鏈接標簽( a 標簽)
link_text 定位方法: find_element_by_link_text()
實作案例 -5 需求:打開百度首頁,通過 link_text( 鏈接文本 ) 定位到 hao123 按鈕,并進行點
擊操作

6partial_link_text定位

說明: partial_link_text 定位是對 link_text 定位的補充, partial_link_text 為模糊匹配; link_text 為全部 匹配,
前提: 定位的元素是鏈接標簽( a 標簽)
partial_link_text 定位方法: find_element_by_partial_link_text()
通過傳入 a 標簽區域文本或全部文本來定位元素,要求輸入的文本能夠唯一找到這個元素
實作案例 -6 需求:打開百度新聞( http://news.baidu.com/ ),通過 partial_link_text 定位任何一條新聞, 并進行點擊操作

7:元素組定位

元素組定位方式: find_elements_by_xxx
作用:
1. 查找返還定位所有符合條件的元素
2. 返還的定位元素格式為串列格式
說明:
串列資料格式的讀取需要指定下標(下標從 0 開始)
案例要求:打開論壇登錄界面
http://49.233.108.117:3000/signin ),通過元素組定位,
輸入用戶名和密碼,

xpath和css定位

為什么要學習xpathcss定位

? 在實際專案中標簽沒有 id/name/class 屬性
? id/name/class 屬性值為動態獲取,隨著重繪或加載而變化
? xpath css 定位可以解決以上兩類問題

xpath定位

xpath概述:
1. xpath即為 xml path 的簡稱,它是一種用來確定 XML 檔案中某部分位置的語言,
2. HTML可以看做是 XML 的一種實作,所以 selenium 用戶可以使用這種強大的語言在 web 應用中來
定位元素
3. xpath為強大的語言,是因為它有非常靈活的定位策略,
定位方法: find_element_by_xpath()
xpath定位策略(方式)
1. 路徑定位-- 絕對路徑、相對路徑
2. 利用元素屬性定位
3. 層級與屬性結合定位
4. 屬性與邏輯定位結合

1:路徑定位(絕對/相對路徑)

絕對路徑:從最外層元素到指定元素之間所有經過元素層級路徑;如 /html/body/div/p[2]
提示:
1. 絕對路徑是以/ 開始
2. 通過瀏覽器查看元素屬性,右擊復制xpath 快速生成
相對路徑:從第一個符合條件元素開始(一般配合屬性來區分);如 //input[@id='kw']
提示:
1. 相對路徑以// 開始
2. 通過瀏覽器查看元素屬性,右擊復制xpath 快速生成

2:利用元素屬性

? 快速定位元素,利用元素唯一屬性;
? 示例: //*[@id='kw']
? 案例要求:打開論壇登錄界面( http://49.233.108.117:3000/signin ),通過 xpath 定位,輸入用戶名和密 碼,

3:層級與屬性結合

? 要找到的元素沒有屬性,但是它的父級有;
? 示例: //*[@id='p1']/input

4:屬性與邏輯結合

? 解決元素之間相同屬性重名問題 ;
? 示例: //*[@id='telA' and @class='telA']

css定位

? css概述:
1. css(Cascading Style Sheets)是一種語言,它用來描述 HTML XML 的元素顯示樣式,
2. css語言中有 css 選擇器,在 selenium 中也可以使用這種選擇器來進行元素定位
3. css定位方式比 xpath 快,而且 css 的語法也非常強大,所以非常推薦這種方式定位
? 定位方法: find_element_by_css_selector()
? css定位策略(方式)
1. id選擇器
2. class選擇器
3. 元素選擇器
4. 屬性選擇器
5. 層級選擇器

1id選擇器

? 根據元素 id 屬性來選擇
? 格式: #id 屬性值 如: #userA( 選擇 id 屬性值為 userA 的所有元素 )
? 案例要求:打開論壇登錄界面( http://49.233.108.117:3000/signin ),通過 css 定位,輸入用戶名和密 碼,

2class選擇器

? 根據元素 class 屬性來選擇
? 格式: .class 屬性值 如: .telA( 選擇 class 屬性值為 telA 的所有元素 )

3:元素選擇器

? 根據元素標簽名來選擇
? 格式: element 如: input( 選擇所有 input 元素 )

4:屬性選擇器

? 根據元素的屬性名和值來選擇
? 格式: [attribute=value] 如: [type='password']( 選擇所有 type 屬性為 password 的值 )
? 打開論壇登錄界面( http://49.233.108.117:3000/signin ),通過定位,輸入用戶名和密碼,

5:層級選擇器

? 根據元素的父子關系來選擇
? 格式: element>element 如: p>input( 返還所有 p 元素下所有的 input 元素 )
? 提示: > 可以用空格代替,如 p input 或者 p [type='password']

總結

另一種定位-By

? 匯入 By
? 導包: from selenium.webdriver.comm.by import By
? By 類的方法:
?
find_element(By.ID,'userA')
?
需要兩個引數,第一個引數為定位的型別,由 By 提供,第二個引數為定位的具體方式,

下拉串列定位

下拉串列定位

? 下拉串列常見的前端表現形式: Select+Option ul+li

Select型別的下拉框

? 案例 1 http://127.0.0.1:5000/signin 進行登錄操作,再定位 select 選項中的內容
? 12306 訂票, url https://kyfw.12306.cn/otn/leftTicket/init?linktypeid=dc
? 操作流程:打開網址 -- 對發車時間進行切換
? 步驟
1. 導包: from selenium.webdriver.support.ui import Select
2. 定位Select 元素
3. 定位option 選項:通過呼叫 Select 的方法來進行定位選項 : select_by_value() select_by_index()
select_by_visible_text()

ul+li型別的下拉框

? 定位非 <select> 標簽的下拉選單中的選項,需要兩個步驟, 先定位到下拉選單,再對其中
的選項進行定位,
案例 2 :禪道撰寫用例, url http://127.0.0.1/index.php
解題思路:
1. 先定位到ul ,并且將定位到的值賦給變數 a
a=driver.find_element_by_id("ul id")
2. 再用變數a 去找到 li
a.find_element_by_id("li id").click()

元素常用屬性

webElement常用屬性與方法

? 定位到元素后,除了對元素進行操作,還可以獲取元素的一些屬性資訊,常見的屬性資訊:
1. 獲取元素的尺寸: ele.size
2. 獲取元素的坐標: ele.location
3. 獲取元素的文本內容: ele.text text 是存在在一對 a 標簽、 p 標簽或 div 標簽中的文本內容,如果 是標簽中的value 值,是不能通過這種方式來獲取到的,
4. 獲取元素的屬性值: ele.get_attribut( 屬性名 ) 通過傳入不同的屬性名來獲取對應的屬性值
5. 獲取頁面的url driver.current_url url 獲取再進行判斷,是一種常用的檢查方式
6. 獲取頁面的title driver.title title 獲取再進行判斷,也還是一種常用的檢查方式

微信搜一搜【程式員阿沐】關注這個文縐縐的程式員,關注后主頁點擊【領取資料】有我準備的一線大廠面試資料和簡歷模板,希望大家都能找到心儀的作業,學習是一條時而郁郁寡歡,時而開懷大笑的路,加油,如果你通過努力成功進入到了心儀的公司,一定不要懈怠放松,職場成長和新技術學習一樣,不進則退,如果有幸我們江湖再見!

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/289500.html

標籤:其他

上一篇:用10個真實案列帶你掌握MySQL調優

下一篇:前端未來的發展前景如何?

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more