YAML 语言:它实质上是一种通用的数据串行化格式
一、yaml基本语法规则:

  • 大小写敏感
  • 使用缩进表示层级关系
  • 缩进时不允许使用Tab键,只允许使用空格
  • 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
  • #表示注释,从这个字符一直到行尾,都会被解析器忽略,这个和python的注释一样

二、yaml支持的数据结构有三种:

  • 对象:键值对的集合,又称为映射(mapping)/ 哈希(hashes) / 字典(dictionary)
  • 数组:一组按次序排列的值,又称为序列(sequence) / 列表(list)
  • 纯量(scalars):单个的、不可再分的值。字符串、布尔值、整数、浮点数、Null、时间、日期
    对象
    1.python字典
# python
{"user": "root",
"pwd": "123456,
}

yaml上的格式

    user: rootpwd: 123456

2.python字典嵌套字典

"qt": {"user": "root","pwd": "123456,}

yaml上的格式

qt:user: rootpwd: 123456

序列
1.python的list

[{'list1': 123456},
{'list2': 333333},
{'list3': 444124}]

yaml格式

- list1: 123456
- list2: 333333
- list3: 444124

纯量
纯量是最基本的、不可再分的值,这里不再举例了。。。。

第三方库需要安装:pip install pyyaml

三、实例

yaml文件写下自己需要的配置
python25.yaml

logger:name: python25level: DEBUGfile: python25.txtexcel:file: cases.xlsxsheet: login# request配置
request:method: postdemo:- guiyin- hello

用python读取yaml

import yaml
# 读取 yaml 配置, 加载配置项
f = open('python25.yaml', encoding='utf-8')data = yaml.load(f.read(), Loader=yaml.FullLoader)
print(data)
print(type(data))f.close()

结果截图:

升级,自己获取yaml的路径,并读取yaml


import yaml
import os# 获取当前脚本所在文件夹路径
curPath = os.path.dirname(os.path.realpath(__file__))
# 获取yaml文件路径
yamlPath = os.path.join(curPath, "python25.yaml")# open方法打开直接读出来
f = open(yamlPath, 'r', encoding='utf-8')
cfg = f.read()
print(type(cfg))  # yaml自己读出来是字符串d = yaml.load(cfg,Loader=yaml.FullLoader)  # 用load方法转字典
print(d)
print(type(d))

运行结果:


上边介绍的是yaml文件的读取,下边文件介绍把数据写入yaml
四、把数据写入yaml中

import os
import yaml
data = [{'list1': 123456},
{'list2': 333333},
{'list3': 444124}]curpath = os.path.dirname(os.path.realpath(__file__))
yamlpath = os.path.join(curpath, "data.yaml")# 写入到yaml文件
with open(yamlpath, "w", encoding="utf-8") as f:yaml.dump(data, f,allow_unicode=True)

运行结果截图如下:
data.yaml

五、yaml的封装,封装成类
config_1.yaml

demo:
- guiyin
- hello
excel:file: cases.xlsxsheet: login
logger:file: python25.txtlevel: DEBUGname: 修改
request:method: post

读取yaml功能,写入yaml功能

import os
import yamlclass YamlHandler:def __init__(self,file,encoding = 'utf-8'):self.file = fileself.encoding = encoding
#读取yaml数据def get_ymal_data(self):with open(self.file,encoding=self.encoding) as f:data = yaml.load(f.read(),Loader=yaml.FullLoader)return data
#写入yaml数据def write_yaml(self,data):"""有中文需要添加allow_unicode=True:param yaml_path::param data::param encoding::return:"""with open(self.file,'w',encoding=self.encoding) as f:yaml.dump(data,stream=f,allow_unicode = True)if __name__ == '__main__':# 获取当前脚本所在文件夹路径curPath = os.path.dirname(os.path.realpath(__file__))# 获取yaml文件路径yamlPath = os.path.join(curPath, "config_1.yaml")# file_path = os.path.join(os.path.dirname(os.path.abspath("__file__")),"config_1.yaml")test_yaml = YamlHandler(yamlPath)#读取yaml配置文件的值data = test_yaml.get_ymal_data()print(data)#对配置文件的内容进行修改并写入data['logger']['name'] = '修改'test_yaml.write_yaml(data)print(data)print(type(data))

运行结果:

python操作配置文件yaml数据读取数据写入相关推荐

  1. python操作xls文件,读取、写入、调整

    1.读取excel import xlrd import xlwt from datetime import date,datetime# 打开文件 workbook = xlrd.open_work ...

  2. 【Unity3D读取数据】(一)Txt文档操作(创建、读取、写入、修改)

    推荐阅读 CSDN主页 GitHub开源地址 Unity3D插件分享 简书地址 我的个人博客 QQ群:1040082875 大家好,我是佛系工程师☆恬静的小魔龙☆,不定时更新Unity开发技巧,觉得有 ...

  3. 【Unity3D读取数据】(四)Excel文件操作(创建、读取、写入、修改)

    推荐阅读 CSDN主页 GitHub开源地址 Unity3D插件分享 简书地址 我的个人博客 QQ群:1040082875 大家好,我是佛系工程师☆恬静的小魔龙☆,不定时更新Unity开发技巧,觉得有 ...

  4. python操作数据库及并封装数据库函数

    python操作数据库及并封装数据库函数 目录 python操作数据库及并封装数据库函数 一.前提 1.pyton连接数据库需要先安装pymysql模块: 2.安装完成后导入pymysql模块: 二. ...

  5. java properties更新_对Java配置文件Properties的读取、写入与更新操作

    String filepath=System.getProperty("user.dir"); 对下面的程序很有用... /** * 实现对Java配置文件Properties的读 ...

  6. java配置文件强制更新_对Java配置文件Properties的读取、写入与更新操作

    对Java配置文件Properties的读取.写入与更新操作 注:当前项目路径是 String filepath=System.getProperty("user.dir"); 对 ...

  7. Java配置文件Properties的读取、写入与更新操作

    /** * 实现对Java配置文件Properties的读取.写入与更新操作 */ package test; import java.io.BufferedInputStream; import j ...

  8. python读excel成数组_python读取excel数据 python怎么从excel中读取数据?

    python怎么从excel中读取数据?分母那么浩瀚,分子那么微弱.唯一就等于没有. #导入包 import xlrd #设置路径 path='C:\\Users\\jyjh\\Desktop\\da ...

  9. 使用Python对Dicom文件进行读取与写入的实现(pydicom 和 SimpleITK)

    这篇文章主要介绍了使用Python对Dicom文件进行读取与写入的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 使用Pyd ...

最新文章

  1. SQL中Group By的使用详解
  2. ZYNQ-7000如何生成从Flash和SD卡启动的镜像文件
  3. 用shell批量修改文件名
  4. 【计算机视觉】究竟谁能解决可解释性 AI?
  5. 一年Java经验应该会些什么
  6. python基于svm的异常检测_[scikit learn]:异常检测-OneClassSVM的替代方案
  7. websocket php MySQL_PHP写了一个websocket服务,mysql连接实例丢失问题怎么解决?
  8. 阿里云服务器是如何计费的?有哪些计费方式
  9. EasyRecovery的工具栏介绍
  10. 调查问卷Html5发展综述
  11. python实现嵌套功能_python3 os进行嵌套操作的实例讲解
  12. 5个不为人知的音乐网站,全网音乐免费听!说什么也不能错过
  13. 使用OTP动态口令(每30s变一次)进行登录认证
  14. PHP面向对象开发:类成员的相关知识
  15. 富贵险中求?回顾AMD历次决策之是非对错(AMD授权中国生产x86之后)
  16. 光速类有哪些最新发表的毕业论文呢?
  17. HTML我的家乡宁夏学生网页设计作品 dreamweaver作业静态HTML网页设计模板 宁夏旅游景点网页作业制作...
  18. 生产物流系统建模与仿真-基于WITNESS建模视频教程
  19. 影响大学生就业的几个关键问题
  20. C++利用opencv调用pytorch训练好的分类模型

热门文章

  1. Debug mode: off变为 on 解决方法
  2. 使用传感器和Matrix实现图片随手机晃动而变换
  3. [FML]学习笔记二 PAC Learning Model
  4. 小程序中如何实现表情组件
  5. 职业教育数字化成行业发展新方向
  6. 中国社交网站(SNS)弊端——隐私
  7. linux cuda 黑屏,Ubuntu下安装Nvidia显卡驱动和Cuda之后黑屏,蓝屏,发生各种错误
  8. ABAP 基本数据类型
  9. ASP.NET MVC Outputcache特性
  10. tongyuekeji123 实战 SQL Server 2008 数据库误删除数据的恢复