前面实现了第一种方法,就是通过写文件,然后参数化读取。现在来讲第二种实现,直接改脚本里面数据。首先jmeter文件存储为xml类型的。我们得熟悉python处理xml.python有几种处理xml的库,这里讲ElementTree 类似一个轻量级的DOM。python3.3之后ElementTree模块会自动寻找可用的C库来加快速度
try:
import xml.etree.cElementTree as ET
except ImportError:
import xml.etree.ElementTree as ET
tree = ET.parse("country.xml") #
root = tree.getroot() # 获取根节点
XML文件格式介绍:
text tail
例: hello123456789
tag,即标签,用于标识该元素表示哪种数据,即APP_KEY
attrib,即属性,用Dictionary形式保存,即{'channel' = 'CSDN'}
text,文本字符串,可以用来存储一些数据,即hello123456789
tail,尾字符串,并不是必须的,例子中没有包含。
ElementTree解析XML文件的过程:导入ElementTree,
import xml.etree.ElementTree as ET
解析Xml文件找到根节点:直接解析XML文件并获得根节点,
tree = ET.parse('country_data.xml') root = tree.getroot()
解析字符串,
root = ET.fromstring(country_data_as_string)
遍历根节点可以获得子节点,然后就可以根据需求拿到需要的字段了。
查找指定的子节点:当XML文件较大或者其中的子节点tag非常多的时候,一个一个获取是比较麻烦的而且有很多不是我们需要的,这样我们可以通过find('nodeName')或者findall('nodeName')方法来查找指定tag的节点。
find('nodeName'):表示在该节点下,查找其中第一个tag为nodeName的节点。
findall('nodeName'):表示在该节点下,查找其中所有tag为nodeName的节点。
2.遍历