基于python全局設置id 自動化測試元素定位過程解析
背景:
在自動化化測試過程中,不方便準確獲取頁面的元素,或者在重構過程中方法修改造成元素層級改變,因此通過設置id準備定位。
一、python準備工作:
功能:用自動化的方式進行批量處理。 比如,你想要在大量的文本文件中執(zhí)行查找/替換,或者以復雜的方式對大量的圖片進行重命名和整理。
語法用例:
#!/usr/bin/python //腳本語言的第一行,只對 Linux/Unix 用戶適用,用來指定本腳本用什么解釋器來執(zhí)行,即:調用 /usr/bin 下的 python 解釋器,推薦使用#!/usr/bin/env python 會去環(huán)境設置尋找 python 目錄,可以增強代碼的可移植性,不要寫死路徑 print "Hello, World!" // 輸出內容 python script.py // 使用python變量調用腳本:#!/usr/bin/python 被忽略,等同于注釋 python3 hello.py // pyhton3版本執(zhí)行 ./script.py // 在python程序執(zhí)行:#!/usr/bin/python 指定解釋器的路徑
中文編碼:Python3.X 源碼文件默認使用utf-8編碼,所以可以正常解析中文,無需指定 UTF-8 編碼。查看:python -V
#!/usr/bin/python # -*- coding: UTF-8 -*- //默認的編碼格式是 ASCII 格式無法輸出漢字 print "你好,世界";
#!/usr/bin/python3 // python3版本 print("Hello, World!")
下載:Python官網:https://www.python.org/
設置環(huán)境變量(一般自動設置cmd):
path=%path%;C:\Python //注意: C:\Python 是指Python的安裝目錄
下面幾個重要的環(huán)境變量,它應用于Python:
變量名 | 描述 |
---|---|
PYTHONPATH | PYTHONPATH是Python搜索路徑,默認我們import的模塊都會從PYTHONPATH里面尋找。 |
PYTHONSTARTUP | Python啟動后,先尋找PYTHONSTARTUP環(huán)境變量,然后執(zhí)行此變量指定的文件中的代碼。 |
PYTHONCASEOK | 加入PYTHONCASEOK的環(huán)境變量, 就會使python導入模塊的時候不區(qū)分大小寫. |
PYTHONHOME | 另一種模塊搜索路徑。它通常內嵌于的PYTHONSTARTUP或PYTHONPATH目錄中,使得兩個模塊庫更容易切換。 |
擴展:
1.集成開發(fā)環(huán)境(IDE:Integrated Development Environment): PyCharm
2.對于 Python 學習的新手來說,安裝 Anaconda 包管理軟件 是一個不錯的選擇
3.cmd 美化參考:https://zhuanlan.zhihu.com/p/31904974
二、實際應用:對指定元素添加id屬性
正則函數:
re.match(pattern, string, flags=0) // 參數說明:正則規(guī)則,字符串,標志位,如果字符串不符合正則表達式,則匹配失敗 re.search(pattern, string, flags=0) // 匹配整個字符串,直到找到一個匹配。
例:
#!/usr/bin/python3 import re line = "Cats are smarter than dogs"; // 貓比夠更小 matchObj = re.match( r'dogs', line, re.M|re.I) if matchObj: print ("match匹配 : ", matchObj.group()) // No match else: print ("No match!!") matchObj = re.search( r'dogs', line, re.M|re.I) if matchObj: print ("search匹配: ", matchObj.group()) // dogs else: print ("No match!!")
實例:
#!/usr/bin/python # -*- coding: UTF-8 -*- import os import re import random count=0 allbutton=set() def buttonid(m): return "<el-button id='kp_but_%s' " % str(round(random.random()*10000)) for root, dirs, files in os.walk(".\src", topdown=False): for name in files: if os.path.splitext(name)[-1] == ".vue": # print( os.path.splitext(name)[-1]) # print(name) filePath=os.path.join(root, name) file=open(filePath, mode='r+',encoding='UTF-8') content=file.read() searchObj=re.search( r'<el-button\s+', content, re.M|re.I) if searchObj: content = re.sub(r'<(el-button\s+)(?![a-zA-Z=\'\.;\%\-:"\s0-9@]*:?id=[a-zA-Z;=\'\.\%\-:"+$\s0-9@]*)',buttonid , content) count+=1 # allbutton.add(searchObj.group()) file=open(filePath, mode='w',encoding='UTF-8') lent=file.write(content) print(lent) else: print('None') # print(content) # for name in dirs: # print(os.path.join(root, name)) print(count)
使用說明:
1.將當前文件test.py放在項目根目錄(與./src同級);
2.下載python執(zhí)行該文件即可:
python test.py
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Python實現的基于優(yōu)先等級分配糖果問題算法示例
這篇文章主要介紹了Python實現的基于優(yōu)先等級分配糖果問題算法,涉及Python針對列表的遍歷、判斷、計算等相關操作技巧,需要的朋友可以參考下2018-04-04pandas pd.cut()與pd.qcut()的具體實現
本文主要介紹了pandas pd.cut()與pd.qcut()的具體實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-01-01Pytorch 如何加速Dataloader提升數據讀取速度
這篇文章主要介紹了Pytorch 加速Dataloader提升數據讀取速度的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-05-05