FluentNormalization 1.0.0

dotnet add package FluentNormalization --version 1.0.0                
NuGet\Install-Package FluentNormalization -Version 1.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="FluentNormalization" Version="1.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add FluentNormalization --version 1.0.0                
#r "nuget: FluentNormalization, 1.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install FluentNormalization as a Cake Addin
#addin nuget:?package=FluentNormalization&version=1.0.0

// Install FluentNormalization as a Cake Tool
#tool nuget:?package=FluentNormalization&version=1.0.0                

PersonNormalizer README

This project demonstrates how to use a custom normalizer for cleaning up and transforming string properties in a class. The normalizer provides flexible, chainable normalization rules that can be applied to properties of the Person class.

Table of Contents

Overview

The project includes two main components:

  • AbstractNormalizer<T>: This class serves as the base for creating custom normalizers for any class. It allows you to apply a series of normalization rules to properties of type T.
  • PersonNormalizer: This is a concrete implementation of AbstractNormalizer<Person> designed to clean up and normalize the FirstName and LastName properties of a Person object.

PersonNormalizer

The PersonNormalizer applies a series of predefined rules to the FirstName and LastName properties. You can easily modify or extend these rules to fit your specific needs.

Default Rules for FirstName

  • Convert the name to lowercase.
  • Remove all whitespace in the name.
  • Normalize diacritics (e.g., "�" becomes "e").
  • Remove certain prefixes like "Mr.", "Dr.".
  • Capitalize the first letter of each word (title case).
  • Trim any punctuation marks.
  • Replace specific words (e.g., "John" becomes "Jonathan").

Default Rules for LastName

  • Convert the last name to lowercase.
  • Remove all whitespace.
  • Normalize diacritics.
  • Trim any punctuation marks.
  • Capitalize the first letter of each word.

Normalization Rules

The following normalization rules are implemented and can be applied to any property in the normalizer:

  • ToLower(): Converts the string to lowercase.
  • RemoveWhitespace(): Removes all whitespace in the string.
  • NormalizeDiacritics(): Replaces accented characters (e.g., "�" becomes "e").
  • ToTitleCase(): Capitalizes the first letter of each word in the string.
  • RemovePrefix(IEnumerable<string>): Removes specified prefixes from the string.
  • RemoveWords(IEnumerable<string>): Removes specified words from anywhere in the string.
  • TrimPunctuation(): Removes punctuation from the string.
  • Replace(Dictionary<string, string>): Replaces occurrences of keys in the string with their corresponding values.

Examples

Example 1: Basic Normalization

var person = new Person
{
    FirstName = " J�rgen ",
    LastName = "Smith "
};

var normalizer = new PersonNormalizer();
var normalizedPerson = normalizer.Normalize(person);

Console.WriteLine(normalizedPerson.FirstName); // Output: jurgen
Console.WriteLine(normalizedPerson.LastName);  // Output: smith

Output:
FirstName: jurgen
LastName: smith

Example 2: Normalizing Accented Characters

var person = new Person
{
    FirstName = " �lodie ",
    LastName = " Garc�a "
};

var normalizer = new PersonNormalizer();
var normalizedPerson = normalizer.Normalize(person);

Console.WriteLine(normalizedPerson.FirstName); // Output: elodie
Console.WriteLine(normalizedPerson.LastName);  // Output: garcia

Output:
FirstName: elodie
LastName: garcia

Example 3: Replacing Words and Removing Prefixes

var person = new Person
{
    FirstName = " Mr. John ",
    LastName = " Dr. Emily "
};

var normalizer = new PersonNormalizer();
var normalizedPerson = normalizer.Normalize(person);

Console.WriteLine(normalizedPerson.FirstName); // Output: Jonathan
Console.WriteLine(normalizedPerson.LastName);  // Output: Emily

Output:
FirstName: Jonathan
LastName: Emily

Example 4: Trimming Punctuation

var person = new Person
{
    FirstName = "John!",
    LastName = "Emily..."
};

var normalizer = new PersonNormalizer();
var normalizedPerson = normalizer.Normalize(person);

Console.WriteLine(normalizedPerson.FirstName); // Output: John
Console.WriteLine(normalizedPerson.LastName);  // Output: Emily

Output:
FirstName: John
LastName: Emily

Conclusion

This normalization system provides a flexible and extendable way to clean and standardize string properties in your classes. You can easily add more normalization rules to fit specific needs, ensuring that all your data is consistent and properly formatted.

Product 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.0 133 9/5/2024