ValveKeyValue 0.20.0.417
dotnet add package ValveKeyValue --version 0.20.0.417
NuGet\Install-Package ValveKeyValue -Version 0.20.0.417
<PackageReference Include="ValveKeyValue" Version="0.20.0.417" />
<PackageVersion Include="ValveKeyValue" Version="0.20.0.417" />
<PackageReference Include="ValveKeyValue" />
paket add ValveKeyValue --version 0.20.0.417
#r "nuget: ValveKeyValue, 0.20.0.417"
#:package ValveKeyValue@0.20.0.417
#addin nuget:?package=ValveKeyValue&version=0.20.0.417
#tool nuget:?package=ValveKeyValue&version=0.20.0.417
<h1><img src="./Misc/logo.png" width="64" align="center"> Valve's KeyValue for .NET</h1>
This library aims to be fully compatible with Valve's various implementations of KeyValues format parsing (believe us, it's not consistent).
KeyValues1
Used by Steam and the Source engine.
Deserializing text
Basic deserialization
var stream = File.OpenRead("file.vdf"); // or any other Stream
var kv = KVSerializer.Create(KVSerializationFormat.KeyValues1Text);
KVObject data = kv.Deserialize(stream);
Console.WriteLine(data["some key"]);
Typed deserialization
public class SimpleObject
{
    public string Name { get; set; }
    public string Value { get; set; }
}
var stream = File.OpenRead("file.vdf"); // or any other Stream
var kv = KVSerializer.Create(KVSerializationFormat.KeyValues1Text);
KVObject data = kv.Deserialize<SimpleObject>(stream);
Options
Deserialize method also accepts an KVSerializerOptions object.
By default, operating system specific conditionals are enabled based on the OS the code is running on (RuntimeInformation).
KVSerializerOptions accepts has the following options:
- Conditions- List of conditions to use to match conditional values.
- HasEscapeSequences- Whether the parser should translate escape sequences (e.g.- \n,- \t).
- EnableValveNullByteBugBehavior- Whether invalid escape sequences should truncate strings rather than throwing a- InvalidDataException.
- FileLoader- Provider for referenced files with- #includeor- #basedirectives.
var options = new KVSerializerOptions
{
    HasEscapeSequences = true,
};
options.Conditions.Clear(); // Remove default conditionals set by the library
options.Conditions.Add("X360WIDE");
var stream = File.OpenRead("file.vdf");
var kv = KVSerializer.Create(KVSerializationFormat.KeyValues1Text);
var data = kv.Deserialize(stream, options);
Deserializing binary
Essentially the same as text, just change KeyValues1Text to KeyValues1Binary.
Serializing to text
class DataObject
{
    public string Name { get; set; }
    public string Developer { get; set; }
    [KVProperty("description")]
    public string Summary { get; set; }
    [KVIgnore]
    public string ExtraData { get; set; }
}
var data = new DataObject
{
    Developer = "Valve Software",
    Name = "Dota 2",
    Summary = "Dota 2 is a complex game.",
    ExtraData = "This will not be serialized."
};
using var stream = File.OpenWrite("file.vdf");
var kv = KVSerializer.Create(KVSerializationFormat.KeyValues1Text);
kv.Serialize(stream, data, "root object name");
Serializing to binary
Essentially the same as text, just change KeyValues1Text to KeyValues1Binary.
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | 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. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. | 
- 
                                                    net8.0- No dependencies.
 
NuGet packages (11)
Showing the top 5 NuGet packages that depend on ValveKeyValue:
| Package | Downloads | 
|---|---|
| GameFinder.StoreHandlers.Steam Library for finding games installed with Steam. | |
| HGV.Basilius Clients for download hero, ability, and items from daily cache provided by DotaBuff | |
| GameLib.NET GameLib.NET is a library to give .NET developers easy access to the users installed game launchers and installed games. | |
| ValveResourceFormat Library to decompile Valve Source 2 files | |
| BD.SteamClient 次元超越 SteamClient 库 | 
GitHub repositories (12)
Showing the top 12 popular GitHub repositories that depend on ValveKeyValue:
| Repository | Stars | 
|---|---|
| beeradmoore/dlss-swapper | |
| SteamAutoCracks/Steam-auto-crack 
                                                            Steam Game Automatic Cracker
                                                         | |
| KSP-CKAN/CKAN 
                                                            The Comprehensive Kerbal Archive Network
                                                         | |
| ValveResourceFormat/ValveResourceFormat 
                                                            Source 2 Viewer is a powerful tool that allows you to browse VPK archives, view, extract, and decompile Source 2 assets, including maps, models, materials, textures, sounds, and more.
                                                         | |
| GoldenPotato137/PotatoVN 
                                                            一款Visual Novel管理软件
                                                         | |
| terrymacdonald/DisplayMagician 
                                                            DisplayMagician is an open source tool for automatically configuring your displays and sound for a game or application from a single Windows Shortcut. 
                                                         | |
| overtools/OWLib 
                                                            DataTool is a program that lets you extract models, maps, and files from Overwatch.
                                                         | |
| ruarai/CompilePal 
                                                            A tool to assist in the compiling of source engine maps
                                                         | |
| saul/demofile-net 
                                                            Blazing fast cross-platform demo parser library for Counter-Strike 2 and Valve's Deadlock, written in C#.
                                                         | |
| hedge-dev/HedgeModManager 
                                                            Multiplatform rewrite of Hedge Mod Manager
                                                         | |
| MDModsDev/MuseDashModTools 
                                                            UI app made by Avalonia framework for Muse Dash Mods
                                                         | |
| SteamDatabase/SteamAppInfo 
                                                            Parser for appinfo.vdf and packageinfo.vdf files used by the Steam client
                                                         | 
| Version | Downloads | Last Updated | 
|---|---|---|
| 0.20.0.417 | 3,516 | 8/10/2025 | 
| 0.13.1.398 | 21,581 | 4/5/2025 | 
| 0.12.0.391 | 7,428 | 11/2/2024 | 
| 0.11.0.378 | 79,473 | 7/3/2024 | 
| 0.10.0.360 | 181,268 | 3/22/2024 | 
| 0.9.0.267 | 108,491 | 6/5/2023 | 
| 0.8.2.162 | 208,344 | 8/26/2022 | 
| 0.8.0.139 | 4,162 | 2/9/2022 | 
| 0.8.0.133 | 1,198 | 2/4/2022 | 
| 0.7.1 | 1,139 | 1/13/2022 | 
| 0.6.0.5 | 1,490 | 9/8/2021 | 
| 0.5.0.4 | 3,475 | 9/17/2020 | 
| 0.4.2 | 1,789 | 7/30/2020 | 
| 0.4.1 | 1,070 | 7/29/2020 | 
| 0.3.1.152 | 12,369 | 6/23/2020 | 
| 0.3.0.149 | 1,040 | 6/23/2020 | 
| 0.3.0.144 | 1,967 | 3/4/2020 | 
| 0.2.1.107 | 3,995 | 1/16/2018 | 
| 0.2.0.105 | 1,899 | 1/13/2018 | 
| 0.1.0.102-AppVeyor | 1,657 | 1/13/2018 | 
| 0.0.1 | 2,917 | 3/31/2016 | 
View release notes at https://github.com/ValveResourceFormat/ValveKeyValue/releases