返回顶部
首页 > 资讯 > 后端开发 > Python >Python接口自动化浅析yaml配置文件原理及用法
  • 399
分享到

Python接口自动化浅析yaml配置文件原理及用法

2024-04-02 19:04:59 399人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录一、yaml介绍及使用01 yaml简介02 yaml语法规则03 yaml数据结构对象数组纯量二、yaml配置文件的使用01 yaml配置文件准备02 yaml配置文件格式校验

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

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

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

以下主要介绍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模块中提取出load、dump函数。


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

到此这篇关于Python接口自动化浅析yaml配置文件原理及用法的文章就介绍到这了,更多相关Python接口自动化yaml配置文件内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Python接口自动化浅析yaml配置文件原理及用法

本文链接: https://lsjlt.com/news/133524.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作