AppStream.SmartParser
1.0.3
See the version list below for details.
dotnet add package AppStream.SmartParser --version 1.0.3
NuGet\Install-Package AppStream.SmartParser -Version 1.0.3
<PackageReference Include="AppStream.SmartParser" Version="1.0.3" />
paket add AppStream.SmartParser --version 1.0.3
#r "nuget: AppStream.SmartParser, 1.0.3"
// Install AppStream.SmartParser as a Cake Addin #addin nuget:?package=AppStream.SmartParser&version=1.0.3 // Install AppStream.SmartParser as a Cake Tool #tool nuget:?package=AppStream.SmartParser&version=1.0.3
SmartParser
<b>SmartParser</b> is an open-source utility library designed to transform unstructured data — such as raw text or images — into structured, strongly-typed objects. By leveraging the power of Large Language Models (LLMs) like those from OpenAI, Smart-Parser helps you integrate AI-driven content parsing directly into your workflows or applications.
Setup & Installation
Prerequisites:
- .NET 9.0 or later
- Access to an OpenAI API key (or other compatible LLM provider)
Installation:
Add the Smart-Parser package via NuGet:
dotnet add package AppStream.SmartParser
Configure Services and Settings
Code-Based Configuration
services.AddSmartParser(options =>
{
options.DeploymentName = "MyDeployment";
options.OpenAiEndpoint = "https://your-openai-endpoint.azure.com/";
options.OpenAiCredentialKey = "my-key";
});
Environment Variables
services.AddSmartParser(options =>
{
options.DeploymentName = Environment.GetEnvironmentVariable("DEPLOYMENT_NAME") ?? "DefaultDeployment";
options.OpenAiEndpoint = Environment.GetEnvironmentVariable("OPENAI_ENDPOINT") ?? "https://your-openai-endpoint.azure.com/";
options.OpenAiCredentialKey = Environment.GetEnvironmentVariable("OPENAI_CREDENTIAL_KEY") ?? "default-key";
});
AppSettings File
appsettings.json
sample:
{
"SmartParser": {
"DeploymentName": "MyDeployment",
"OpenAiEndpoint": "https://your-openai-endpoint.azure.com/",
"OpenAiCredentialKey": "my-key"
}
}
var configuration = new ConfigurationBuilder()
.AddJsonFile("appsettings.json")
.Build();
services.AddSmartParser(configuration.GetSection("SmartParser").Bind);
Usage
Once you've configured SmartParser in your project, parsing is straightforward. Whether you're working with unstructured text or scanned images, SmartParser can help produce typed objects tailored to your needs.
Text
Simply pass your raw text content along with any guiding considerations, and SmartParser will return a typed object reflecting the extracted information.
public class SimpleResult
{
public string Name { get; set; } = "";
public int Age { get; set; }
public string? Title { get; set; }
public string Summary { get; set; } = "";
}
public class Example
{
private readonly ISmartParser _smartParser;
public Example(ISmartParser smartParser)
{
_smartParser = smartParser;
}
public async Task RunAsync(CancellationToken cancellationToken)
{
// Input text might be unstructured content describing a person
var inputText = """
John Doe is a 29-year-old software engineer who specializes in building
cross-platform mobile applications. He has worked at several leading
tech companies and contributed to a wide range of open-source projects.
Recently, John has focused on building secure, user-friendly interfaces
that help everyday users understand complex data. He occasionally speaks
at industry conferences, discussing user experience and modern development
practices.
""";
var result = await _smartParser.ParseAsync<SimpleResult>(
inputText,
// Considerations (optional hints) for the parser:
"""
- Keep the output factual.
- If a title isn't clearly stated, set it to null.
- Keep the summary as concise as possible.
""",
cancellationToken);
if (result == null)
{
throw new InvalidOperationException("Parsing failed.");
}
Console.WriteLine($"Name: {result.Name}");
Console.WriteLine($"Age: {result.Age}");
Console.WriteLine($"Title: {(result.Title ?? "none")}");
Console.WriteLine($"Summary: {result.Summary}");
}
}
Image
Just like with text, you can supply an image URL and parsing considerations, and the parser will produce a typed result based on the visual content.
// Suppose this URL points to an image of a CV/resume
var cvImageUrl = "https://example.com/cv.jpg";
var result = await _smartParser.ParseImageAsync<SimpleResult>(
cvImageUrl,
"""
Extract the individual's name, approximate age (if stated), any professional title, and a concise summary of their experience.
If a professional title is not clearly stated, set it to null.
""",
cancellationToken);
if (result == null)
{
Console.WriteLine("CV parsing from image failed.");
return;
}
Console.WriteLine($"Name: {result.Name}");
Console.WriteLine($"Age: {result.Age}");
Console.WriteLine($"Title: {(result.Title ?? "none")}");
Console.WriteLine($"Summary: {result.Summary}");
Contributing
Contributions to this open source library are highly appreciated! If you're interested in helping out, please feel free to submit a pull request with your changes. We welcome contributions of all kinds, whether it's bug fixes, new features, or just improving the documentation. Please ensure that your code is well-documented, tested, and adheres to the coding conventions used in the project. Don't hesitate to reach out if you have any questions or need help getting started. You can open an issue on GitHub or email us at contact@appstream.studio - we're happy to assist you in any way we can.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. 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. |
-
net9.0
- Azure.AI.OpenAI (>= 2.1.0)
- Microsoft.Extensions.DependencyInjection (>= 9.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.0)
- Microsoft.Extensions.Options (>= 9.0.0)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 9.0.0)
- Microsoft.Extensions.Options.DataAnnotations (>= 9.0.0)
- NJsonSchema (>= 11.1.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.