python处理yaml文件
yaml文件简介
yaml 文件是一种数据序列化语言,广泛用于配置文件、日志文件、等
语言特点
- 大小写敏感
- 使用缩进表示层级关系
- 缩进时不允许使用Tab键,只允许使用空格。
- 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
yaml数据结构
yaml语言包含三种数据结构:
- mappings (hashes/dictionaries) 对象
- sequences (arrays/lists) 数组
- scalars (strings/numbers) 纯量
以下是标记语言和转化为python 对象后的输出
数组
数组以 - 和 空格 来标记
- name1
- name2
- name3
output: 转为list
['name1', 'name2', 'name3']
对象
对象用: 和 空格 标识
name: Ling
email: ww.aa.com
output: 转为dict
{'name': 'Ling', 'email': 'ww.aa.com'}
数据对象混合
对象value为数组/ 对象
american:
- Boston Red Sox
- Detroit Tigers
- New York Yankees
national:
- New York Mets
- Chicago Cubs
- Atlanta Braves:
- A
- B
多维数组
-
- Boston Red Sox
- Detroit Tigers
- New York Yankees
-
- New York Mets
- Chicago Cubs
- Atlanta Braves
纯量
- 字符串
- 布尔值
- 整数
- 浮点数
- Null
- 时间
- 日期
boolean:
- TRUE #true,True,TRUE都可以
- FALSE #false,False, FALSE都可以
float:
- 3.14
- 6.8523015e+5 #可以使用科学计数法
int:
- 123
- 0b1010_0111_0100_1010_1110 #二进制表示
kongzhi:
parent: ~ #使用~表示null
class: null #null也表示null
string:
- 哈哈
- 'Hello world: from this way' #如果字符串之中包含空格或特殊字符,需要放在引号之中,可以使用双引号或者单引号包裹特殊字符
- 写多行 #换行服会转义成空格
date:
- 2018-02-17 #日期必须使用ISO 8601格式,即yyyy-MM-dd
- 2018-02-17 12:23:34 #标准带时间格式
output如下:
{'boolean': [True, False], 'float': [3.14, 685230.15], 'int': [123, 685230], 'kongzhi': {'parent': None, 'class': None}, 'string': ['哈哈', 'Hello world: from this way', '写多行'], 'date1': [datetime.date(2018, 2, 17), datetime.datetime(2018, 2, 17, 12, 23, 34)]}
注意上述date转换成python 字典后,转成json会报错
xx={'date1': [datetime.date(2018, 2, 17), datetime.datetime(2018, 2, 17, 12, 23, 34)]}
print(json.dumps(xx, indent=4))
# 运行错误如下:
TypeError: Object of type date is not JSON serializable
注释
注释以“#” 标识
- name1 #this is first name
- name2
- name3
锚点和引用
& 用来建立锚点,<< 表示合并到当前数据,* 用来引用锚点
举例如下:
defaults: &defaults
adapter: postgres
host: localhost
development:
database: myapp_development
<<: *defaults
test:
database: myapp_test
<<: *defaults
python操作yaml文件
安装工具包
pip install pyyaml
pyyaml官网文档
https://pyyaml.org/wiki/PyYAMLDocumentation
常用方法
这里的常用方法和 json 操作类似
将yml文件转换成 python中数据
由于 yaml.load()
方法不安全,建议使用yaml.safe_load()
函数
import yaml
# 直接打开文件,获取文件内容,转换成python dict 数据格式
# 这里要考虑关闭文件
file_data = open('./config/login_data.yaml')
data = yaml.load(file_data, yaml.SafeLoader) # 相当于 safe_load 方法
print(data)
file1.close()
# 使用with 方法,可以不用手动关闭文件
# 这里设置encoding 是为了yaml 文件有中文时进行处理
with open('./config/login_data.yaml', encoding='utf-8') as f:
elem_locators = yaml.safe_load(f) # 传入的是 yaml字符串或者文件句柄
print(elem_locators)
将python数据转换成 写入yml 文件
使用 yaml.dump 函数,暂时不在此介绍
清空yaml文件
trucate()
yaml 常用的方法就是 读取、写入 和 清空
读取文件的内容
可以加多个fixtrue
可以加多个断言
注意点
yaml中有中文
如yaml中有中文,需要使用 字符串.encode('utf-8')或打开文件时指定encoding='utf-8'
参考链接
yaml语言介绍
- YAML 入门教程: https://www.runoob.com/w3cnote/yaml-intro.html
- YAML Ain’t Markup Language (YAML™) version 1.2: https://yaml.org/spec/1.2.2/#chapter-2-language-overview
- YAML 语言教程: https://www.ruanyifeng.com/blog/2016/07/yaml.html
python 操作yaml
- PyYAML Documentation https://pyyaml.org/wiki/PyYAMLDocumentation
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)