• Python接口自动化之yaml配置文件


    VOL 119

    04

    2020-05

    今天距2021年241天

    这是ITester软件测试小栈第119次推文

    点击上方蓝字“ITester软件测试小栈“关注我,每周一五早上 07:30准时推送。

    微信公众号后台回复“资源测试工具包“简历模板”领取测试资源

    本文3435字,阅读约需9分钟

    在上一篇Python接口自动化测试系列文章:Python接口自动化之数据驱动主要介绍openpyxl操作excel,结合ddt实现数据驱动。

    在自动化过程中,需要使用配置文件储存数据,比如数据库信息、账号信息、域名等。

    其中,yaml文件是一种配置文件类型,相比较iniconf配置文件来说,更加的简洁,操作也更加简单,同时可以存放不同类型的数据。

    以下主要介绍yaml语法、yaml储数据,封装类读写yaml配置文件。

    yaml介绍及使用

    01 yaml简介

    YAML 语言( /ˈjæməl/ )的设计目标,就是方便人类读写。它实质上是一种通用的数据串行化格式。

    YAML 是一种非常灵活的格式,几乎是 JSON 的超集。除了支持注释、换行符分隔、多行字符串、裸字符串和更灵活的类型系统之外,YAML 也支持引用文件,以避免重复代码。

    02 yaml语法规则

    基本语法规则:

    • 大小写敏感;

    • 使用缩进表示层级关系;

    • 缩进时不允许使用Tab键,只允许使用空格;

    • 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可;

    • # 表示注释,从这个字符一直到行尾,都会被解析器忽略;

    03 yaml数据结构

    • 对象:键值对的集合,又称为映射(mapping)哈希(hashes) 字典(dictionary);

    • 数组:一组按次序排列的值,又称为序列(sequence) 列表(list);

    • 纯量(scalars):单个的、不可再分的值;

    ▌对象

    Map(属性和值)(键值对)的形式:

    key:(空格)value :表示一对键值对,空格不可省略。

    person:
        name: vivi
        age: 18
    


    一行写法:

    person:{name: vivi,age: 18}
    

    相当于JSON格式:

    {"name":"vivi","age":18}
    

    数组

    一组连词线开头的行,构成一个数组。数组前加有 “-” 符号,符号与值之间需用空格分隔。

    color:
       - red
       - blue
       - green
    

    一行写法:

    color: [red,blue,green]
    

    相当于JSON

    ["red","blue","green"]
    

    纯量

    单个的、不可再分的值。(如:字符串、bool值、整数、浮点数、时间、日期、null等)

    n1: 8
    n2: 8.8
    n3: true
    n4: false
    n5: 'vivi'
    

    yaml配置文件的使用

    01  yaml配置文件准备

    在项目下新建一个目录config,在目录下新建一个文件config.yaml。

    在config.yaml配置文件中写入数据库配置。

    mysql:
      host: "127.0.0.1"
      port: 3306
      user: "vivi"
      password: "123456"
      db: "ITester"
      charset: "utf8"
    

    02  yaml配置文件格式校验

    刚了解yaml的同学,可能对yaml格式掌握不熟练,出现格式错误,这里推荐一个在线网站,用于校验我们写的yaml文件格式是否正确。

    在线地址:

    http://www.bejson.com/validators/yaml/ 

    yaml配置文件读写


    python中读取yaml文件前需要安装pyyaml和导入yaml模块。

    01  安装pyYaml

    在python中读取yaml文件,需要用到第三方模块PyYaml。

    安装命令:

    pip install pyYaml

    02  yaml模块源码解析

    从yaml模块中提取出loaddump函数

    def load(stream, Loader=None):
        """
        Parse the first YAML document in a stream
        and produce the corresponding Python object.
        """
        if Loader is None:
            load_warning('load')
            Loader = FullLoader
        loader = Loader(stream)
        try:
            return loader.get_single_data()
        finally:
            loader.dispose()
            
    def dump(data, stream=None, Dumper=Dumper, **kwds):
        """
        Serialize a Python object into a YAML stream.
        If stream is None, return the produced string instead.
        """
        return dump_all([data], stream, Dumper=Dumper, **kwds)
    

    load:

    将yaml流转化为python字典;

    dump:

    将python对象转化为yaml流;

    03  读写yaml配置文件

    将读写yaml配置文件的类进行封装。

    在common目录下新建一个文件,config_handler.py用于读写yaml。

    config_handler.py

    import yaml
    
    class YamlHandler:
        def __init__(self,file):
            self.file = file
    
        def read_yaml(self,encoding='utf-8'):
            """读取yaml数据"""
            with open(self.file, encoding=encoding) as f:
                return yaml.load(f.read(), Loader=yaml.FullLoader)
                
        def write_yaml(self, data, encoding='utf-8'):
            """向yaml文件写入数据"""
            with open(self.file, encoding=encoding, mode='w') as f:
                return yaml.dump(data, stream=f, allow_unicode=True)
    
    if __name__ == '__main__':
        data = {
            "user":{
                "username": "vivi",
                "password": "123456"
            }
        }
        # 读取config.yaml配置文件数据
        read_data = YamlHandler('../config/config.yaml').read_yaml()
        # 将data数据写入config1.yaml配置文件
        write_data = YamlHandler('../config/config1.yaml').write_yaml(data)
        print(read_data)
    
    

    运行结果为:

    {'mysql': {'host': '127.0.0.1', 'port': 3306, 'user': 'vivi', 'password': '123456', 'db': 'ITester', 'charset': 'utf8'}}
    

    写入到config1.yaml的数据。

    config1.yaml

    user:
      password: '123456'
      username: vivi
    

    总结:本文主要介绍yaml语法、yaml储存数据,封装类读取yaml配置文件。

    下一篇:Python接口自动化之数据库操作

    以上


    That‘s all

    更多系列文章

    敬请期待

    ITester软件测试小栈

    往期内容宠幸

    1.Python接口自动化-接口基础(一)


    2.Python接口自动化-接口基础(二)


    3.Python接口自动化-requests模块之get请求


    4.Python接口自动化-requests模块之post请求


    5.Python接口自动化之cookie、session应用


    6.Python接口自动化之Token详解及应用


    7.Python接口自动化之requests请求封装


    8.Python接口自动化之unittest单元测试


    9.Python接口自动化之登录接口测试


    10.Python接口自动化之数据驱动

    快来星标 置顶 关注

    <<  滑动查看下一张图片  >>

    今日问题

    在接口自动化测试项目中,你通常使用什么格式的配置文件? 

    (欢迎在下方留言区发表你的看法)


     后台 回复"资源"取干货

    回复"简历模板"领取简历

    测试交流Q群:727998947

    点亮一下在看,你更好看

  • 相关阅读:
    POJ 3659 Cell Phone Network(树的最小支配集)(贪心)
    2017 Hackatari Codeathon C. Arcade(DP)(滚动数组)
    2017 Hackatari Codeathon B. 2Trees(深搜)(想法)
    Codeforces Round #307 (Div. 2) E. GukiZ and GukiZiana(分块)
    Codeforces Round #407 (Div. 2) D. Weird journey(欧拉路)
    HDU 5669 Road(线段树建树)(分层图最短路)
    【bzoj2763】[JLOI2011]飞行路线 (分层图最短路)(优先队列dij)
    sed命令基本用法
    linux文本编辑器vim
    oracle row_number() over(partition by .. order by ..)和rank() over(partition by .. order by ..) 和dense_rank() over(partition by .. order by ..)的相似点与区别
  • 原文地址:https://www.cnblogs.com/ITester520/p/13203305.html
Copyright © 2020-2023  润新知