python读写yaml

news/2024/10/30 13:26:33/

python读写yaml

  • 1. python读取yaml文件
    • 1.1. YAML 简介
    • 1.2. YAML 语法
    • 1.3. 安装第三方yaml文件处理库PyYAML
    • 1.4. yaml文件读取

1. python读取yaml文件

1.1. YAML 简介

YAML,Yet Another Markup Language的简写,通常用来编写项目配置,也可用于数据存储,相比conf等配置文件要更简洁。

1.2. YAML 语法

  • 支持的数据类型:
    字典、列表、字符串、布尔值、整数、浮点数、Null、时间等
  • 基本语法规则:
    1、大小写敏感
    2、使用缩进表示层级关系
    3、相同层级的元素左侧对齐
    4、键值对用冒号 “:” 结构表示,冒号与值之间需用空格分隔
    5、数组前加有 “-” 符号,符号与值之间需用空格分隔
    6、None值可用null 和 ~ 表示
    7、多组数据之间使用3横杠—分割
    8、# 表示注释,但不能在一段代码的行末尾加 #注释,否则会报错

1.3. 安装第三方yaml文件处理库PyYAML

python没有自带的处理yaml文件的库,需要下载第三方库PyYAML 或 ruamel.yaml ,这里我们安装PyYAML。

pip install pyyaml
# 下载速度慢的话加上清华镜像源
pip install pyyaml -i https://pypi.tuna.tsinghua.edu.cn/simple

1.4. yaml文件读取

待读取的文件为yolov8.yaml

# Ultralytics YOLO 🚀, AGPL-3.0 license
# YOLOv8 object detection model with P3-P5 outputs. For Usage examples see https://docs.ultralytics.com/tasks/detect# Parameters
nc: 80  # number of classes
scales: # model compound scaling constants, i.e. 'model=yolov8n.yaml' will call yolov8.yaml with scale 'n'# [depth, width, max_channels]n: [0.33, 0.25, 1024]  # YOLOv8n summary: 225 layers,  3157200 parameters,  3157184 gradients,   8.9 GFLOPss: [0.33, 0.50, 1024]  # YOLOv8s summary: 225 layers, 11166560 parameters, 11166544 gradients,  28.8 GFLOPsm: [0.67, 0.75, 768]   # YOLOv8m summary: 295 layers, 25902640 parameters, 25902624 gradients,  79.3 GFLOPsl: [1.00, 1.00, 512]   # YOLOv8l summary: 365 layers, 43691520 parameters, 43691504 gradients, 165.7 GFLOPsx: [1.00, 1.25, 512]   # YOLOv8x summary: 365 layers, 68229648 parameters, 68229632 gradients, 258.5 GFLOPs# YOLOv8.0n backbone
backbone:# [from, repeats, module, args]- [-1, 1, Conv, [64, 3, 2]]  # 0-P1/2- [-1, 1, Conv, [128, 3, 2]]  # 1-P2/4- [-1, 3, C2f, [128, True]]- [-1, 1, Conv, [256, 3, 2]]  # 3-P3/8- [-1, 6, C2f, [256, True]]- [-1, 1, Conv, [512, 3, 2]]  # 5-P4/16- [-1, 6, C2f, [512, True]]- [-1, 1, Conv, [1024, 3, 2]]  # 7-P5/32- [-1, 3, C2f, [1024, True]]- [-1, 1, SPPF, [1024, 5]]  # 9# YOLOv8.0n head
head:- [-1, 1, nn.Upsample, [None, 2, 'nearest']]- [[-1, 6], 1, Concat, [1]]  # cat backbone P4- [-1, 3, C2f, [512]]  # 12- [-1, 1, nn.Upsample, [None, 2, 'nearest']]- [[-1, 4], 1, Concat, [1]]  # cat backbone P3- [-1, 3, C2f, [256]]  # 15 (P3/8-small)- [-1, 1, Conv, [256, 3, 2]]- [[-1, 12], 1, Concat, [1]]  # cat head P4- [-1, 3, C2f, [512]]  # 18 (P4/16-medium)- [-1, 1, Conv, [512, 3, 2]]- [[-1, 9], 1, Concat, [1]]  # cat head P5- [-1, 3, C2f, [1024]]  # 21 (P5/32-large)- [[15, 18, 21], 1, Detect, [nc]]  # Detect(P3, P4, P5)

读取测试代码:

import yamlwith open('./yolov8.yaml', 'r', encoding='utf-8') as f:result = yaml.load(f.read(), Loader=yaml.FullLoader)
print(result)
print(type(result))
print(result['nc'], type(result['nc']))
print(result['scales'], type(result['scales']))print(result['scales']['n'], type(result['scales']['n']))print(result['backbone'], type(result['backbone']))
print(len(result['backbone']))print(result['backbone'][0])
print(len(result['backbone'][0]))
print(result['backbone'][0][2], type(result['backbone'][0][2]))
print(result['backbone'][0][3], type(result['backbone'][0][3]))

输出:

{'nc': 4, 'scales': {'n': [0.33, 0.25, 1024], 's': [0.33, 0.5, 1024], 'm': [0.67, 0.75, 768], 'l': [1.0, 1.0, 512], 'x': [1.0, 1.25, 512]}, 'backbone': [[-1, 1, 'Conv', [64, 3, 2]], [-1, 1, 'Conv', [128, 3, 2]], [-1, 3, 'C2f', [128, True]], [-1, 1, 'Conv', [256, 3, 2]], [-1, 6, 'C2f', [256, True]], [-1, 1, 'Conv', [512, 3, 2]], [-1, 6, 'C2f', [512, True]], [-1, 1, 'Conv', [1024, 3, 2]], [-1, 3, 'C2f', [1024, True]], [-1, 1, 'SPPF', [1024, 5]]], 'head': [[-1, 1, 'nn.Upsample', ['None', 2, 'nearest']], [[-1, 6], 1, 'Concat', [1]], [-1, 3, 'C2f', [512]], [-1, 1, 'nn.Upsample', ['None', 2, 'nearest']], [[-1, 4], 1, 'Concat', [1]], [-1, 3, 'C2f', [256]], [-1, 1, 'Conv', [256, 3, 2]], [[-1, 12], 1, 'Concat', [1]], [-1, 3, 'C2f', [512]], [-1, 1, 'Conv', [512, 3, 2]], [[-1, 9], 1, 'Concat', [1]], [-1, 3, 'C2f', [1024]], [[15, 18, 21], 1, 'Detect', ['nc']]]}
<class 'dict'>
4 <class 'int'>
{'n': [0.33, 0.25, 1024], 's': [0.33, 0.5, 1024], 'm': [0.67, 0.75, 768], 'l': [1.0, 1.0, 512], 'x': [1.0, 1.25, 512]} <class 'dict'>
[0.33, 0.25, 1024] <class 'list'>
[[-1, 1, 'Conv', [64, 3, 2]], [-1, 1, 'Conv', [128, 3, 2]], [-1, 3, 'C2f', [128, True]], [-1, 1, 'Conv', [256, 3, 2]], [-1, 6, 'C2f', [256, True]], [-1, 1, 'Conv', [512, 3, 2]], [-1, 6, 'C2f', [512, True]], [-1, 1, 'Conv', [1024, 3, 2]], [-1, 3, 'C2f', [1024, True]], [-1, 1, 'SPPF', [1024, 5]]] <class 'list'>
10
[-1, 1, 'Conv', [64, 3, 2]]
4
Conv <class 'str'>
[64, 3, 2] <class 'list'>

参考:Python基础笔记1-Python读写yaml文件(使用PyYAML库)

参考:
参考:


http://www.ppmy.cn/news/283151.html

相关文章

【剑指 Offer】22,链表中倒数第k个节点。 难度等级:简单。思路:快慢指针

文章目录 1. 题目2. 我的解法&#xff1a;遍历两次链表3. 更优解法&#xff1a;快慢指针&#xff0c;遍历一次链表 1. 题目 输入一个链表&#xff0c;输出该链表中倒数第k个节点。为了符合大多数人的习惯&#xff0c;本题从1开始计数&#xff0c;即链表的尾节点是倒数第1个节点…

CPU多核心和单核心的区别在哪?

大家都知道服务器有单核心以及多核心的区别&#xff0c;那么这两个区别大吗&#xff1f;CPU主要功能是解释计算机指令以及处理计算机软件中的数据。CPU由运算器、控制器和寄存器及实现它们之间联系的数据、控制及状态的总线构成。那么CPU多核心和单核心的区别在哪&#xff1f; …

单核多线程与多核多线程

单核多线程与多核多线程 或许有些同学对于单核多线程和多核多线程有点误区&#xff0c;因为会听到一些同学问为什么单核能处理多线程&#xff0c;总结了一些干货&#xff0c;下面会通俗说明下。 线程和进程是什么 线程是CPU调度和分配的基本单位&#xff08;可以理解为CPU只…

酷睿双核之解析

【酷睿双核名字的由来】 酷睿是英文单词core的音译&#xff0c;意为“核心”&#xff0c;所以酷睿双核就是双核处理器的意思。 英特尔酷睿双核处理器是基于英特尔桌面、移动、WOODCREST服务器架构的处理器&#xff0c;能够提供超强性能和超低功耗。 “酷睿”是一款领先节能的新…

了解身边的超线程、双核、双cpu

一、从三者的工作原理和概念理解:   (1)超线程(HT):   超线程(Hyperthreading Technology)技术就是通过采用特殊的硬件指令&#xff0c;可以把两个逻辑内核模拟成两个物理芯片&#xff0c;在单处理器中实现线程级的并行计算&#xff0c;同时在相应的软硬件的支持下大幅…

CPU多核心和单核心有哪些区别?

最近小编收到蛮多客户在问CPU多核心和单核心的区别大不大&#xff0c;在CPU上该如何做选择&#xff0c;今天简单给大家来说一说&#xff0c;CPU主要功能是解释计算机指令以及处理计算机软件中的数据。CPU由运算器、控制器和寄存器及实现它们之间联系的数据、控制及状态的总线构…

奔腾双核和酷睿双核的区别(转)

对于选择笔记本&#xff0c;CPU是重中之重&#xff0c;直接关系到运算的速度和整个笔记本的性能现在笔记本市场上&#xff0c;主打的也就是AMD和INTEL&#xff0c;由于2006年底到2007年初&#xff0c;AMD连续推出了一系列的双核产品&#xff0c;以其低廉的价格和较好的性价比抢…

【历史上的今天】9 月 8 日:阿里开放平台计划;英特尔发布首款双核酷睿处理器;我国研制全数字高清晰度电视系统

整理 | 王启隆 透过「历史上的今天」&#xff0c;从过去看未来&#xff0c;从现在亦可以改变未来。 今天是 2021 年 9 月 8 日&#xff0c;在 1956 年的今天&#xff0c;中国成功试制新型喷气式飞机&#xff0c;让蔚蓝的天空上响彻中华雄狮的咆哮。而在计算机领域&#xff0c;…