基于python全局设置id 自动化测试元素定位的方法分享
时间:2019-09-15 作者:桥南小院 来源:互联网背景:
在自动化化测试过程中,不方便准确获取页面的元素,或者在重构过程中方法修改造成元素层级改变,因此通过设置id准备定位。
一、python准备工作:
功能:用自动化的方式进行批量处理。 比如,你想要在大量的文本文件中执行查找/替换,或者以复杂的方式对大量的图片进行重命名和整理。
语法用例:
#!/usr/bin/python //脚本语言的第一行,只对 Linux/Unix 用户适用,用来指定本脚本用什么解释器来执行,即:调用 /usr/bin 下的 python 解释器,推荐使用#!/usr/bin/env python 会去环境设置寻找 python 目录,可以增强代码的可移植性,不要写死路径 print "Hello, World!" // 输出内容 python script.py // 使用python变量调用脚本:#!/usr/bin/python 被忽略,等同于注释 python3 hello.py // pyhton3版本执行 ./script.py // 在python程序执行:#!/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/
设置环境变量(一般自动设置cmd):
path=%path%;C:\Python //注意: C:\Python 是指Python的安装目录
下面几个重要的环境变量,它应用于Python:
变量名 | 描述 |
---|---|
PYTHONPATH | PYTHONPATH是Python搜索路径,默认我们import的模块都会从PYTHONPATH里面寻找。 |
PYTHONSTARTUP | Python启动后,先寻找PYTHONSTARTUP环境变量,然后执行此变量指定的文件中的代码。 |
PYTHONCASEOK | 加入PYTHONCASEOK的环境变量, 就会使python导入模块的时候不区分大小写. |
PYTHONHOME | 另一种模块搜索路径。它通常内嵌于的PYTHONSTARTUP或PYTHONPATH目录中,使得两个模块库更容易切换。 |
扩展:
1.集成开发环境(IDE:Integrated Development Environment): PyCharm
2.对于 Python 学习的新手来说,安装 Anaconda 包管理软件 是一个不错的选择
3.cmd 美化参考:https://zhuanlan.zhihu.com/p/31904974
二、实际应用:对指定元素添加id属性
正则函数:
re.match(pattern, string, flags=0) // 参数说明:正则规则,字符串,标志位,如果字符串不符合正则表达式,则匹配失败 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执行该文件即可:
python test.py
以上就是本文的全部内容,希望对大家的学习有所帮助
- 相关推荐
- 用Python爬取B站5000 条视频,揭秘为何千万人为它流泪!
- Python教程:如何用xlrd和xlwt库读和写Excel表格?
- Python安装MySQL-python:EnvironmentError的解决办法
- 分享:Python2和Python3有那些差异?
- Python 的内置对象都藏了哪些小秘密?
- 实战干货!用案例让你一文搞懂python网络爬虫
- Python教程:图像处理模块ndimage用法实例分析
- Python教程:代理IP爬虫的使用方法
- Python教程:如何使用scipy模块实现一维卷积运算示例?
- Python:关于内存分配时的那些小秘密分享
- python技巧:global关键字的用法详解
- Python教程:深入了解python在HDA中的应用
- python技巧:SSLerror的requests证书问题解决方法
- PyCharm教程:搭建Spark开发环境的几个步骤
- Python开发技巧:openpyxl读取单元格字体颜色过程解析
- Python教程:面向对象之Web静态服务器
- Python教程:如何为终端提供持久性历史记录
- Python技巧分享:自动登录淘宝并保存登录信息的方法
- Python数据分析:利用Flask动态展示 Pyecharts 图表数据方法
- python3教程:如何搭建微型的web服务器?
- python技巧:xlwt如何设置单元格的自定义背景颜色
- 如何解决Python字符串和正则表达式中的反斜杠('\')问题?
- Python开发技巧:编写一个简单登录功能过程解析
- Python编程:postman传递当前时间戳实例详解
- Python爬虫教程:使用beautifulSoup4爬取名言网案例代码分享
- python开发:动态迁移solr数据过程分享
- python数据分析:用线性回归预测股票价格的代码分析
- Python教程:数据分析模块pandas用法详解
- Python3教程:pandas.merge用法详解
- Python爬虫案例:如何爬取豆瓣电影信息?附代码实例
- python开发:如何编写简单端口扫描器?
- Django框架教程:Pagination分页实现代码实例
- python爬虫实例:猫眼电影和电影天堂数据csv和mysql存储过程
- Python教程:实现TCP探测目标服务路由轨迹的原理与方法详解