最近自动化测试参数化使用了yaml文件进行存放,简单记录读取和写入操作
1.读取如下yaml文件中的具体value值代码如下
#测试环境IP、端口
host: localhost:8080
---
#仿真环境IP、端口
host: localhost:8081
def filePath(fileDir, fileName):
return os.path.join(
os.path.dirname(os.path.dirname(__file__)), fileDir, fileName)
def readYaml(filePath):
with open(filePath, 'r', encoding='utf-8') as f:
return list(yaml.safe_load_all(f))
fileDir = 'config'
file = 'config.yaml'
data = readYaml(filePath(fileDir, file))
print(data[0]['host']) # 打印结果为:localhost:8080
2.写入操作,常用作上个操作返回的值将其写入yaml文件,供后面操作读取使用,yaml文件及参考代码如下:
def set_state(docNumber, key, value):
file_name = "test.yaml"
with open(file_name, 'r', encoding="utf-8") as f:
doc = list(yaml.safe_load_all(f)) # 将类型转换为list类型
# print(list(doc))
doc[docNumber][key] = value
with open(file_name, 'w', encoding="utf-8") as f:
yaml.safe_dump_all(doc, f, default_flow_style=False)
set_state(value='http://122.123.124.125:8888',
docNumber=1,
key='host')
执行后的结果为:
host: localhost:8080
---
host: http://122.123.124.125:8888
注意:yaml文档由“---”分隔,如果任何流(例如文件)包含多个文档,则应使用yaml.safe_load_all
函数,而不是yaml.safe_load;
写入非“---”分隔的文档时,使用yaml.safe_load、yaml.safe_dump即可,同时不需要转换类型;参考代码如下:
def set_state(key, value):
file_name = "test.yaml"
with open(file_name, 'r', encoding="utf-8") as f:
doc = yaml.safe_load(f)
doc[key] = value
with open(file_name, 'w', encoding="utf-8") as f:
yaml.safe_dump(doc, f, default_flow_style=False)