YamlDotNet 16.1.0
Prefix ReservedSee the version list below for details.
Requires NuGet 2.8 or higher.
dotnet add package YamlDotNet --version 16.1.0
NuGet\Install-Package YamlDotNet -Version 16.1.0
<PackageReference Include="YamlDotNet" Version="16.1.0" />
paket add YamlDotNet --version 16.1.0
#r "nuget: YamlDotNet, 16.1.0"
// Install YamlDotNet as a Cake Addin #addin nuget:?package=YamlDotNet&version=16.1.0 // Install YamlDotNet as a Cake Tool #tool nuget:?package=YamlDotNet&version=16.1.0
YamlDotNet
Appveyor | NuGet |
---|---|
YamlDotNet is a YAML library for netstandard and other .NET runtimes.
YamlDotNet provides low level parsing and emitting of YAML as well as a high level object model similar to XmlDocument. A serialization library is also included that allows to read and write objects from and to YAML streams.
YamlDotNet's conformance with YAML specifications:
YAML Spec | YDN Parser | YDN Emitter |
---|---|---|
v1.1 | ✓ | ✓ |
v1.2 | ✓ |
What is YAML?
YAML, which stands for "YAML Ain't Markup Language", is described as "a human friendly data serialization standard for all programming languages". Like XML, it allows to represent about any kind of data in a portable, platform-independent format. Unlike XML, it is "human friendly", which means that it is easy for a human to read or produce a valid YAML document.
The YamlDotNet library
The library has now been successfully used in multiple projects and is considered fairly stable. It is compatible with the following runtimes:
- netstandard 2.0
- netstandard 2.1
- .NET 6.0
- .NET 8.0
- .NET Framework 4.7
Quick start
Here are some quick samples to get you started which can be viewed in this fiddle.
Serialization from an object to a string
using YamlDotNet.Serialization;
using YamlDotNet.Serialization.NamingConventions;
...
var person = new Person
{
Name = "Abe Lincoln",
Age = 25,
HeightInInches = 6f + 4f / 12f,
Addresses = new Dictionary<string, Address>{
{ "home", new Address() {
Street = "2720 Sundown Lane",
City = "Kentucketsville",
State = "Calousiyorkida",
Zip = "99978",
}},
{ "work", new Address() {
Street = "1600 Pennsylvania Avenue NW",
City = "Washington",
State = "District of Columbia",
Zip = "20500",
}},
}
};
var serializer = new SerializerBuilder()
.WithNamingConvention(CamelCaseNamingConvention.Instance)
.Build();
var yaml = serializer.Serialize(person);
System.Console.WriteLine(yaml);
// Output:
// name: Abe Lincoln
// age: 25
// heightInInches: 6.3333334922790527
// addresses:
// home:
// street: 2720 Sundown Lane
// city: Kentucketsville
// state: Calousiyorkida
// zip: 99978
// work:
// street: 1600 Pennsylvania Avenue NW
// city: Washington
// state: District of Columbia
// zip: 20500
Deserialization from a string to an object
using YamlDotNet.Serialization;
using YamlDotNet.Serialization.NamingConventions;
...
var yml = @"
name: George Washington
age: 89
height_in_inches: 5.75
addresses:
home:
street: 400 Mockingbird Lane
city: Louaryland
state: Hawidaho
zip: 99970
";
var deserializer = new DeserializerBuilder()
.WithNamingConvention(UnderscoredNamingConvention.Instance) // see height_in_inches in sample yml
.Build();
//yml contains a string containing your YAML
var p = deserializer.Deserialize<Person>(yml);
var h = p.Addresses["home"];
System.Console.WriteLine($"{p.Name} is {p.Age} years old and lives at {h.Street} in {h.City}, {h.State}.");
// Output:
// George Washington is 89 years old and lives at 400 Mockingbird Lane in Louaryland, Hawidaho.
More information
More information can be found in the project's wiki.
Installing
Just install the YamlDotNet NuGet package:
PM> Install-Package YamlDotNet
If you do not want to use NuGet, you can download binaries here.
YamlDotNet is also available on the Unity Asset Store.
Contributing
Please read CONTRIBUTING.md for guidelines.
Release notes
Please see the Releases at https://github.com/aaubry/YamlDotNet/releases
Sponsorships
A big shout out to all of our sponsors
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 is compatible. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETFramework 4.7
- No dependencies.
-
.NETStandard 2.0
- No dependencies.
-
.NETStandard 2.1
- No dependencies.
-
net6.0
- No dependencies.
-
net8.0
- No dependencies.
NuGet packages (796)
Showing the top 5 NuGet packages that depend on YamlDotNet:
Package | Downloads |
---|---|
KubernetesClient
Client library for the Kubernetes open source container orchestrator. |
|
NJsonSchema.Yaml
JSON Schema reader, generator and validator for .NET |
|
KubernetesClient.Models
Client library for the Kubernetes open source container orchestrator. |
|
NetEscapades.Configuration.Yaml
YAML configuration provider implementation to use with Microsoft.Extensions.Configuration. |
|
RamlToOpenApiConverter
Convert RAML file to Open API Specification |
GitHub repositories (232)
Showing the top 5 popular GitHub repositories that depend on YamlDotNet:
Repository | Stars |
---|---|
2dust/v2rayN
A GUI client for Windows and Linux, support Xray core and others
|
|
microsoft/semantic-kernel
Integrate cutting-edge LLM technology quickly and easily into your apps
|
|
bitwarden/server
Bitwarden infrastructure/backend (API, database, Docker, etc).
|
|
marticliment/UniGetUI
UniGetUI: The Graphical Interface for your package managers. Could be terribly described as a package manager manager to manage your package managers
|
|
Jackett/Jackett
API Support for your favorite torrent trackers
|
Version | Downloads | Last updated |
---|---|---|
16.2.0 | 85,266 | 11/10/2024 |
16.1.3 | 626,918 | 9/26/2024 |
16.1.2 | 200,003 | 9/13/2024 |
16.1.1 | 540 | 9/13/2024 |
16.1.0 | 202,132 | 9/1/2024 |
16.0.0 | 1,509,616 | 7/14/2024 |
15.3.0 | 933,547 | 6/16/2024 |
15.1.6 | 374,541 | 5/29/2024 |
15.1.4 | 3,923,081 | 5/11/2024 |
15.1.2 | 2,517,907 | 2/26/2024 |
15.1.1 | 772,698 | 2/4/2024 |
15.1.0 | 2,875,785 | 1/23/2024 |
13.7.1 | 12,919,505 | 10/15/2023 |
13.7.0 | 99,504 | 10/10/2023 |
13.5.2 | 82,172 | 10/5/2023 |
13.5.1 | 33,114 | 10/5/2023 |
13.5.0 | 3,057 | 10/5/2023 |
13.4.0 | 951,031 | 9/20/2023 |
13.3.1 | 5,189,117 | 8/28/2023 |
13.2.0 | 404,659 | 8/14/2023 |
13.1.1 | 4,437,608 | 6/17/2023 |
13.1.0 | 2,110,306 | 4/16/2023 |
13.0.2 | 1,322,590 | 3/11/2023 |
13.0.1 | 4,881,224 | 2/19/2023 |
13.0.0 | 996,058 | 2/7/2023 |
12.3.1 | 7,377,742 | 12/19/2022 |
12.3.0 | 3,843 | 12/19/2022 |
12.2.1 | 238,095 | 12/14/2022 |
12.2.0 | 313,564 | 12/9/2022 |
12.1.0 | 535,240 | 12/5/2022 |
12.0.2 | 1,946,087 | 10/7/2022 |
12.0.1 | 6,113,126 | 9/17/2022 |
12.0.0 | 3,730,022 | 7/23/2022 |
11.2.1 | 77,613,786 | 6/28/2021 |
11.2.0 | 567,012 | 6/13/2021 |
11.1.3-nullable-enums-0003 | 36,351 | 4/9/2021 |
11.1.1 | 3,358,138 | 4/9/2021 |
11.1.0 | 33,637 | 4/8/2021 |
11.0.1 | 70,430 | 4/1/2021 |
10.1.0 | 70,460 | 3/31/2021 |
10.0.0 | 51,448 | 3/27/2021 |
9.1.4 | 8,357,834 | 1/15/2021 |
8.1.2 | 27,530,875 | 5/28/2020 |
8.1.0 | 9,878,381 | 1/18/2020 |
8.0.0 | 6,772,481 | 10/19/2019 |
7.0.0 | 722,501 | 9/28/2019 |
6.1.2 | 3,052,761 | 7/20/2019 |
6.1.1 | 602,965 | 6/4/2019 |
6.0.0 | 13,256,842 | 3/15/2019 |
5.4.0 | 395,508 | 2/12/2019 |
5.3.1 | 7,931 | 2/12/2019 |
5.3.0 | 1,373,762 | 12/5/2018 |
5.1.0 | 1,972,256 | 9/21/2018 |