前言

yaml文件其实也是一种配置文件类型,相比较ini,conf配置文件来说,更加的简洁,操作也更加简单,同时可以存放不同类型的数据,不会改变原有数据类型,所有的数据类型在读取时都会原样输出,yaml文件依赖python的第三方库PyYaml模块

转载自:https://www.cnblogs.com/linuxchao/p/linuxchao-yaml.html

PyYaml安装

打开CMD执行命令: pip install PyYaml

读yaml文件

1、存字典类型

config.yaml

cnblog: 标题
address: BeiJing
Company: china
age: 18
now: 8.14
empty1: null
empty2: ~

parseyaml.py

import yaml

# 定义yaml文件路径
yaml_path = r'C:\Users\ADMIN\Desktop\自动化测试学习\autotest_bysms\cfg\config.yaml' with open(yaml_path,"r",encoding="utf8") as f:
context=yaml.load(f,Loader=yaml.FullLoader)
print("读取内容", context, type(context))
print(context["cnblog"], type(context["cnblog"]))
print(context["age"], type(context["age"]))
print(context["now"], type(context["now"]))
print(context["empty1"], type(context["empty1"]))

输出

读取内容 {'cnblog': '标题', 'address': 'BeiJing', 'Company': 'china', 'age': 18, 'now': 8.14, 'empty1': None, 'empty2': None} <class 'dict'>
标题 <class 'str'>
18 <class 'int'>
8.14 <class 'float'>
None <class 'NoneType'>
None <class 'NoneType'>

结论

当前输出的内容是一个字典类型,

yaml文件中存储的字符串输出仍是字符串类型,int型仍是int型等,

存储None类型可以使用null,~符号以及None,

这也是区别ini配置文件的地方,

且文件内容使用[key:value]的形式定义,当然key和value也可以使用双引号修饰;

2.yaml存多组数据并读取

config.yaml

cnblog: linux超
address: BeiJing
Company: petrochina
age: 18
now: 8.14
---
name: linux超
gender: 男

parseyaml.py

import yaml

# 定义yaml文件路径
yaml_path = r'C:\Users\ADMIN\Desktop\自动化测试学习\autotest_bysms\cfg\config.yaml' with open(yaml_path,"r",encoding="utf8") as f:
context=yaml.load_all(f,Loader=yaml.FullLoader)
print("读取内容",context,type(context))
for i in context:
print(i)

输出

读取内容 <generator object load_all at 0x000001CD07257040> <class 'generator'>
{'cnblog': 'linux超', 'address': 'BeiJing', 'Company': 'petrochina', 'age': 18, 'now': 8.14}
{'name': 'linux超', 'gender': '男'}

结论:

当yaml文件存储多组数据在一个yaml文件中时,

需要使用3个横杆分割,

读取数据时需要使用load_all方法,

而且此方法返回一个生成器,

需要使用for循环迭代读取每一组数据下面再看一下yaml如何存储列表类型数据

3.yaml存储列表并读取

config.yaml

- linux超
- BeiJing
- petrochina
- 18
- 8.14

parseyaml.py

import yaml

# 定义yaml文件路径
yaml_path = r'C:\Users\ADMIN\Desktop\自动化测试学习\autotest_bysms\cfg\config.yaml' with open(yaml_path,"r",encoding="utf8") as f:
context=yaml.load(f,Loader=yaml.FullLoader) print("读取内容",context,type(context))

输出

读取内容 ['linux超', 'BeiJing', 'petrochina', 18, 8.14] <class 'list'>

结论

当yaml文件存储列表数据时,

需要使用一个横杠[- 元素]表示为列表的一个元素

4.yaml存储元组并读取

config.yml

--- !!python/tuple # 列表转成元组
- 1
- 2
- 3
---
age: !!str 18 # int 类型转换为str

parseyaml.py

import yaml

with open("./config.yml", "r", encoding="utf-8") as f:
context = yaml.load_all(f, Loader=yaml.FullLoader)
for i in context:
print(i)

输出

(1, 2, 3)
{'age': '18'} Process finished with exit code 0

结论:

yaml文件使用两个!!号可以对数据进行类型转换

config.yaml

info:
- user:
username: linux超
password: linuxxiaochao
company:
first: petrochina
second: lemon teacher

parseyaml.py

import yaml

with open("config.yml", "r", encoding="utf8") as f:
context = yaml.load(f, Loader=yaml.FullLoader)
print("读取内容\n", context, type(context))

输出

读取内容
{'info': [{'user': {'username': 'linux超', 'password': 'linuxxiaochao'}}], 'company': {'first': 'petrochina', 'second': 'lemon teacher'}} <class 'dict'>

读文件小结

实际工作中大概就是存储字典,列表,或者相互嵌套的数据较常见,那么在存储和读取时需要掌握以下几点

1.存储字典时,以[key:value]的形式定义

2.存储列表时,需要使用[- 元素]表示列表

3.存储多组数据时,需要每组数据之间使用3个横杠-分割分割

4.数据嵌套时,需要注意缩进,和编写python代码的缩进规则相同,唯一不同是,yaml中的缩进只要统一即可不需要指定缩进多少

5.读取一组数据时,直接使用load(stream, loader)方法, 读取多组数据时需要使用load_all(stream, loader)方法,此方法返回的是一个生成器,需要使用for循环读取每一组数据,还需要注意两个方法中的最好像我代码中一样传递loader参数为FullLoader,否则会报Warnning

写yaml文件

向yaml文件中写数据就比较简单了,直接使用dump方法和dump_all方法即可,无论多复杂的数据都可以直接写入

dump写入一组数据

import yaml

response = {
"status": 1,
"code": "1001",
"data": [
{
"id": 80,
"regname": "toml",
"pwd": "QW&@JBK!#&#($*@HLNN",
"mobilephone": "13691579846",
"leavemount": "0.00",
"type": "1",
"regtime": "2019-08-14 20:24:45.0"
},
{
"id": 81,
"regname": "toml",
"pwd": "QW&@JBK!#&#($*@HLNN",
"mobilephone": "13691579846",
"leavemount": "0.00",
"type": "1",
"regtime": "2019-08-14 20:24:45.0"
}
],
"msg": "获取用户列表成功"
} try:
with open("./config.yml", "w", encoding="utf-8") as f:
yaml.dump(data=response, stream=f, allow_unicode=True)
except Exception as e:
print("写入yaml文件内容失败")
raise e
else:
print("写入yaml文件内容成功")

生成的yaml文件内容

code: '1001'
data:
- id: 80
leavemount: '0.00'
mobilephone: '13691579846'
pwd: QW&@JBK!#&#($*@HLNN
regname: toml
regtime: '2019-08-14 20:24:45.0'
type: '1'
- id: 81
leavemount: '0.00'
mobilephone: '13691579846'
pwd: QW&@JBK!#&#($*@HLNN
regname: toml
regtime: '2019-08-14 20:24:45.0'
type: '1'
msg: 获取用户列表成功
status: 1

dump_all写入多组数据

import yaml

response = {
"status": 1,
"code": "1001",
"data": [
{
"id": 80,
"regname": "toml",
"pwd": "QW&@JBK!#&#($*@HLNN",
"mobilephone": "13691579846",
"leavemount": "0.00",
"type": "1",
"regtime": "2019-08-14 20:24:45.0"
},
{
"id": 81,
"regname": "toml",
"pwd": "QW&@JBK!#&#($*@HLNN",
"mobilephone": "13691579846",
"leavemount": "0.00",
"type": "1",
"regtime": "2019-08-14 20:24:45.0"
}
],
"msg": "获取用户列表成功"
} info = {
"name": "linux超",
"age": 18
} try:
with open("./config.yml", "w", encoding="utf-8") as f:
yaml.dump_all(documents=[response, info], stream=f, allow_unicode=True)
except Exception as e:
print("写入yaml文件内容失败")
raise e
else:
print("写入yaml文件内容成功")

生成的yaml文件内容

code: '1001'
data:
- id: 80
leavemount: '0.00'
mobilephone: '13691579846'
pwd: QW&@JBK!#&#($*@HLNN
regname: toml
regtime: '2019-08-14 20:24:45.0'
type: '1'
- id: 81
leavemount: '0.00'
mobilephone: '13691579846'
pwd: QW&@JBK!#&#($*@HLNN
regname: toml
regtime: '2019-08-14 20:24:45.0'
type: '1'
msg: 获取用户列表成功
status: 1
---
age: 18
name: linux超

写yaml文件小结

1.yaml存储数据规则-多组数据使用---分割,

数据嵌套时注意缩进,

存储字典使用[key: value]的形式,存储列表使用[- 元素]的形式,

使用load读一组数据,使用load_all 可以读多组数据

2.yaml文件写入一组数据直接使用dump方法,写入多组数据使用dump_all方法,

注意写入数据带中文,需要指定参数allow_unicode=True

yaml 文件解析的更多相关文章

  1. yaml文件解析详解

    前言 yaml文件是什么?yaml文件其实也是一种配置文件类型,相比较ini,conf配置文件来说,更加的简洁,操作也更加简单,同时可以存放不同类型的数据,不会改变原有数据类型,所有的数据类型在读取时 ...

  2. YAML文件解析

    YAML是“另一种标记语言”的外语缩写,YAML 是一种比JSON(json多层次{ 与 [ 会被搞晕的)更直观的表现形式,展示上更易查错和关系描述.因为不需要一个专业工具就可以排查正确性.YAML目 ...

  3. springboot中对yaml文件的解析

    一.YAML是“YAML不是一种标记语言”的外语缩写 (见前方参考资料原文内容):但为了强调这种语言以数据做为中心,而不是以置标语言为重点,而用返璞词重新命名.它是一种直观的能够被电脑识别的数据序列化 ...

  4. 使用ruamel.yaml库,解析yaml文件

    在实现的需求如下: 同事提供了一个文本文件,内含200多个host与ip的对应关系,希望能在k8s生成pod时,将这些对应关系注入到/etc/hosts中. 网上看文档,这可以通过扩充pod中的hos ...

  5. python解析yaml文件

    YAML语法规则: http://www.ibm.com/developerworks/cn/xml/x-cn-yamlintro/ 下载PyYAML: http://www.yaml.org/ 解压 ...

  6. 解析YAML文件

    YamlMapFactoryBean yamlMapFactoryBean = new YamlMapFactoryBean(); yamlMapFactoryBean.setResources(ne ...

  7. 用Yaml文件进行元素管理【转】

    原文:http://www.cnblogs.com/milanmi/p/4636503.html 如界面有一个按钮,id号是test.如果进行对象化的话,就是test.click就可以了.不用每次都要 ...

  8. selenium2入门 用Yaml文件进行元素管理 (五)

    比如界面有一个按钮,id号是test.如果进行对象化的话,就是test.click就可以了.不用每次都要去创建test对象.如果id号变了,我们也只需要改一下test的名称就行了. 使用Yaml需要用 ...

  9. golang yaml配置文件解析

    yaml文件语法 此模块内容转自:http://www.ruanyifeng.com/blog/2016/07/yaml.html 大小写敏感 使用缩进表示层级关系 缩进时不允许使用Tab键,只允许使 ...

随机推荐

  1. 【NX二次开发】Block UI 指定方位

    属性说明 属性   类型   描述   常规           BlockID    String    控件ID    Enable    Logical    是否可操作    Group    ...

  2. 【NX二次开发】拉伸的偏置方向猜想与验证

    结论:偏置的方向为曲线方向与拉伸方向的向量叉乘. 在UF_MODL_create_extrusion帮助中有这么一句话:Note that the offset direction is determ ...

  3. Redis五种基础与三种高级数据结构解析

    记得点赞+关注呦. 前言 在 Redis 最重要最基础就属 它丰富的数据结构了,Redis 之所以能脱颖而出很大原因是他数据结构丰富,可以支持多种场景.并且 Redis 的数据结构实现以及应用场景在面 ...

  4. 使用sign签名发送请求

    import CryptoJS from "crypto-js"; import urlencode from "urlencode"; methods:{ a ...

  5. 面试热点|理解TCP/IP传输层拥塞控制算法

    0x00.前言 通过本文你将了解到以下内容: 拥塞控制概念以及其背景 流量控制和拥塞控制的区别与联系 拥塞控制主要过程详解 伙伴们认真学习一下,让offer来得更猛烈些吧! 0x01.TCP/IP协议 ...

  6. Golang编写动态库实现回调函数

    Golang编写动态库实现回调函数 我们现在要做一个动态库,但是C++实在是比较难,于是就想能不能用更简单的golang来实现,golang也就是最近的版本才支持编译成动态库,在网上也没找到可用的案例 ...

  7. Redis之集群

    Redis Cluster是 Redis的分布式解决方案,在3.0版本正式推出,有效地解决了Redis分布式方面的需求.当遇到单机内存.并发.流量等瓶颈时,可以采用Cluster架构方案达到负载均衡的 ...

  8. 14、oracle sql语法

    14.0.注释: 1.单行注释:-- 2.多行注释:/* */ 14.1.sqlplus中的set指令: 1.设置每行显示的数据长度: SET LINESIZE 500; #有效范围是1-32767, ...

  9. oracle查询用户所在表为空的表名

    1 select * from user_tables where num_rows = 0 查询之后发现查询的不全,查询之后发现num_rows为空 select * from user_table ...

  10. centos 8 sonarqube 设置开机自启动解决方案

    编写开机自启动脚本 进入到开机自启动调用文件目录 vim /etc/systemd/system/sonarqube.service [Unit] Description=SonarQube serv ...