PyYAML,一个强大的 Python 库!

news2025/1/11 8:13:47

更多资料获取

📚 个人网站:ipengtao.com


大家好,今天为大家分享一个强大的 Python 库 - pyyaml。

Github地址:https://github.com/yaml/pyyaml/


在处理配置文件、序列化数据等场景中,YAML(YAML Ain’t Markup Language)格式因其简洁、易读易写而备受开发者青睐。Python 中的 PyYAML 库为我们提供了灵活高效地处理 YAML 数据的解析和生成功能。本文将全面介绍 PyYAML 库的原理、基本用法以及一些高级特性,并通过丰富的示例代码展示其强大的功能和实际应用场景。

什么是 Python PyYAML 库?

PyYAML 是 Python 中的 YAML 处理库,它能够将 YAML 格式的文本转换为 Python 中的数据结构(如字典、列表等),并且可以将 Python 数据结构序列化为 YAML 格式的文本。PyYAML 提供了简单易用的接口,使得开发者能够轻松地读取、编辑和生成 YAML 数据。

核心功能

  • 加载 YAML 数据:PyYAML 可以将 YAML 格式的文本加载为 Python 中的数据结构。
  • 导出 YAML 数据:PyYAML 可以将 Python 中的数据结构导出为 YAML 格式的文本。
  • 支持标量类型:PyYAML 支持解析和生成各种标量类型,如字符串、整数、浮点数、布尔值等。
  • 支持序列类型:PyYAML 支持解析和生成列表、字典等序列类型的数据。
  • 支持自定义对象:PyYAML 支持解析和生成自定义对象,并且可以通过扩展标记来实现更复杂的数据转换。

使用方法

1. 安装 PyYAML 库

首先,需要安装 PyYAML 库:

pip install pyyaml

2. 加载 YAML 数据

import yaml

# 加载 YAML 文件
with open('data.yaml', 'r') as file:
    data = yaml.safe_load(file)

print(data)

3. 导出 YAML 数据

import yaml

# Python 数据
data = {'name': 'John', 'age': 30}

# 导出为 YAML 格式文本
yaml_text = yaml.dump(data)
print(yaml_text)

实际应用场景

1. 配置文件解析

PyYAML 可以用于解析各种配置文件,如服务器配置、应用配置等。

# config.yaml
server:
  host: '127.0.0.1'
  port: 8080
database:
  name: 'example'
  user: 'user'
  password: 'password'
import yaml

# 加载配置文件
with open('config.yaml', 'r') as file:
    config = yaml.safe_load(file)

print(config['server']['host'])  # 输出:127.0.0.1

2. 数据序列化与反序列化

PyYAML 可以将 Python 对象序列化为 YAML 格式的文本,也可以将 YAML 格式的文本反序列化为 Python 对象。

import yaml

# Python 对象
data = {'name': 'John', 'age': 30}

# 序列化为 YAML 格式文本
yaml_text = yaml.dump(data)

# 反序列化为 Python 对象
new_data = yaml.safe_load(yaml_text)
print(new_data)

高级功能和进阶用法

1. 自定义标签

PyYAML 支持自定义标签,使得开发者能够自定义数据转换规则。

import yaml

# 自定义标签处理函数
def custom_tag_constructor(loader, node):
    return node.value.upper()

yaml.add_constructor('!custom', custom_tag_constructor)

# 加载 YAML 数据
data = yaml.safe_load('!custom hello')

print(data)  # 输出:HELLO

2. 多文档处理

PyYAML 支持处理包含多个 YAML 文档的文件。

import yaml

# 加载包含多个 YAML 文档的文件
with open('multi_document.yaml', 'r') as file:
    documents = yaml.safe_load_all(file)

for doc in documents:
    print(doc)

总结

通过本文的介绍,深入了解了 Python PyYAML 库的原理、基本用法以及一些高级特性。PyYAML 提供了强大而灵活的功能,使得开发者能够轻松地处理 YAML 格式的数据,包括加载、导出、自定义标签处理等。无论是解析配置文件、序列化数据,还是处理复杂的数据转换,PyYAML 都是一个非常实用的工具,为工作带来更多的便利和效率。


Python学习路线

在这里插入图片描述

更多资料获取

📚 个人网站:ipengtao.com

如果还想要领取更多更丰富的资料,可以点击文章下方名片,回复【优质资料】,即可获取 全方位学习资料包。

在这里插入图片描述
点击文章下方链接卡片,回复【优质资料】,可直接领取资料大礼包。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1563525.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

雷勒过滤与您相约2024第13届生物发酵展

参展企业介绍 青岛雷勒过滤科技有限公司是一家致力于不锈钢过滤网,涂料筛,滤袋等研发、生产和服务一体的综合型公司。雷勒专业生产各种高品质的不锈钢过滤元件,用于各种关键的过滤与分离环节。 雷勒拥有先进的生产设备,完善的产…

BGP-BGP选路、BGP4+

BGP-BGP选路,BGP4 支持IPv6的BGP,又称为MP-BGP,BGP4 BGP:外部网关协议、使用TCP作为其传输层协议、支持CIDR、增量更新、路径矢量路由协议、无环路、路由策略丰富、可防止路由震荡、易于扩展。 BGP工作原理——报文类型&#x…

信捷 XD/XL plc 单精度/双精度浮点数比较 ECMP,EDCMP

对于单精度浮点数,用ECMP指令。 对于双精度浮点数,用EDCMP指令 注意:EDCMP 指令中寄存器的首地址必须为偶数。

教育信创 | 云轴科技ZStack联合飞腾发布全场景教育信创白皮书

随着数字化时代的到来,教育行业正面临着前所未有的挑战与机遇。为了推动教育行业的数字化转型和信创人才培养,云轴科技ZStack联合飞腾于3月28日正式发布了《教育行业数字化自主创新飞腾生态解决方案白皮书》(简称《教育白皮书》)。…

Day57:WEB攻防-SSRF服务端请求Gopher伪协议无回显利用黑白盒挖掘业务功能点

目录 SSRF-原理&挖掘&利用&修复 SSRF无回显解决办法 SSRF漏洞挖掘 SSRF协议利用 http:// (常用) file:/// (常用) dict:// (常用) sftp:// ldap:// tftp:// gopher:// (…

Python中的全栈开发前端与后端的完美融合【第160篇—全栈开发】

👽发现宝藏 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。【点击进入巨牛的人工智能学习网站】。 Python中的全栈开发:前端与后端的完美融合 全栈开发已成为当今软件开发领域中的…

YOLOv9有效改进专栏汇总|未来更新卷积、主干、检测头注意力机制、特征融合方式等创新![2024/4/1]

​ 专栏介绍:YOLOv9改进系列 | 包含深度学习最新创新,助力高效涨点!!! 专栏介绍 YOLOv9作为最新的YOLO系列模型,对于做目标检测的同学是必不可少的。本专栏将针对2024年最新推出的YOLOv9检测模型&#xff0…

Java数据结构-栈

目录 1. 栈的概念2. 栈的实现2.1 顺序栈2.2 链式栈 3. 栈的应用3.1 栈的使用3.2 括号匹配3.3 逆波兰表达式求值3.4 出栈入栈次序匹配3.4 最小栈 1. 栈的概念 栈是一种顺序结构,只允许在一端进行插入和删除,插入删除的一端叫栈顶,另一端叫栈底…

蓝桥杯嵌入式学习笔记(7):ADC程序设计

目录 前言 1. ADC原理 1.1 主要特性 1.2 模拟输出电路图 2. 使用CubeMX进行源工程的配置 2.1 引脚配置 2.2 配置AD1 2.3 配置AD2 2.4 配置时钟 3. 代码编程 3.1 预备工作 3.2 bsp_adc.h文件编写 3.3 bsp_adc.c文件编写 3.4 main.c编写 3.4.1 时钟函数配置 3…

内网渗透学习-漏洞利用

1、漏洞搜索与利用 漏洞1&#xff1a;后台弱口令 漏洞2&#xff1a; 在yxcms有个留言功能&#xff0c;常常存在存储型xss漏洞 先用<h1>123xss</h1>测试一下会不会解析 登录管理员账号审核留言&#xff0c;发现xss脚本解析了 写入xss弹窗 再次返回管理员审核页面&…

Hive on Spark 配置

目录 1 Hive 引擎简介2 Hive on Spark 配置2.1 在 Hive 所在节点部署 Spark2.2 在hive中创建spark配置文件2.3 向 HDFS上传Spark纯净版 jar 包2.4 修改hive-site.xml文件2.5 Hive on Spark测试2.6 报错 1 Hive 引擎简介 Hive引擎包括&#xff1a;MR&#xff08;默认&#xff09…

leaflet知识点:leaflet.draw的使用指南

一&#xff0c;安装插件 npm i leaflet-draw --save 二&#xff0c;引入插件 import "leaflet-draw"; import "leaflet-draw/dist/leaflet.draw.css";三&#xff0c;使用插件 leaflet-draw的插件使用有两种方法。 1. 作为工具栏控件加入到地图种使用 //…

linux离线安装NodeJs

一、官方下载 地址&#xff1a;Node.js — Download Node.js 选择linux系统版本 为了防止安装过程出现一些适配问题&#xff0c;我没有选择下载最新版&#xff0c;实际应该下载你的前端所用的nodejs版本 未完待续。。

深度解析Android APP加固中的必备手段——代码混淆技术

Android APP 加固是优化 APK 安全性的一种方法&#xff0c;常见的加固方式有混淆代码、加壳、数据加密、动态加载等。下面介绍一下 Android APP 加固的具体实现方式。 混淆代码 使用 ipaguard工具可以对代码进行混淆&#xff0c;使得反编译出来的代码很难阅读和理解&#xff…

3.5网安学习第三阶段第五周回顾(个人学习记录使用)

本周重点 ①SSRF服务器端请求伪造 ②序列化和反序列化 ③Vaudit代码审计 本周主要内容 ①SSRF服务器端请求伪造 一、概述 SSRF: server site request forgery (服务器端请求伪造)。 SSR: 服务端请求&#xff0c;A服务器通过函数向B服务器发送请求。 SSRF发生的前提条件…

idea 报错 Could not list the contents of folder “ftps

idea 报错 Could not list the contents of folder "ftps 解决方案 这里看到了网上的解决方案&#xff0c;顺便再记录一下。打开 【高级】菜单 - 取消勾选 被动模式。然后点击测试连接&#xff0c;显示连接成功&#xff01; ftp中的主动模式和被动模式 主动模式&…

1.JavaEE进阶篇 - 为什么要学习SpringBoot呢?

文章目录 1.为什么要学框架&#xff1f;2.框架的优点展示(SpringBoot VS Servlet)2.1 Servlet 项⽬开发2.1.1 创建项⽬2.1.2 添加引⽤2.1.3 添加业务代码2.1.4 运⾏项⽬(配置tomcat)2.1.5 Maven配置2.1.5.1修改本地Maven仓库地址2.1.5.2 配置settings.xml文件2.1.5.3项目 本地仓…

Nginx开发实战三:替换请求资源中的固定数据

文章目录 1.效果预览2.下载Nginx解压并初始化3.字符串替换模块安装4.修改nginx配置文件并重启 1.效果预览 页面初始效果 页面替换后效果 说明:页面是内网的一个地址&#xff0c;我们通过nginx可以很便捷的将其改为外网访问&#xff0c;但是在外网访问这个地址后&#xff0c…

剑指offer--数组中重复的数字

一.题目描述 在一个长度为 n 的数组 nums 里的所有数字都在 0&#xff5e;n-1 的范围内。数组中某些数字是重复的&#xff0c;但不知道有几个数字重复了&#xff0c;也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。 算法1.排序,然后遍历,时间复杂度O(nlogn),空…

CVE-2023-4427:Out-of-bounds access in ReduceJSLoadPropertyWithEnumeratedKey

文章目录 前言环境搭建for-in && enum cache漏洞分析漏洞利用总结参考 前言 之前分析调试漏洞时&#xff0c;几乎都是对着别人的 poc/exp 调试&#xff0c;感觉对自己的提升不是很大&#xff0c;所以后面分析漏洞时尽可能全面分析&#xff0c;从漏洞产生原理、如何稳定…