https://github.com/ntdls/ntdls.expressionparser
Expression parser for .net. Supports expression nesting, custom variables, custom functions as well as a ton of built in functions.
https://github.com/ntdls/ntdls.expressionparser
Last synced: 22 days ago
JSON representation
Expression parser for .net. Supports expression nesting, custom variables, custom functions as well as a ton of built in functions.
- Host: GitHub
- URL: https://github.com/ntdls/ntdls.expressionparser
- Owner: NTDLS
- License: mit
- Created: 2023-10-13T20:45:49.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-12-31T12:21:53.000Z (4 months ago)
- Last Synced: 2025-03-27T21:22:51.400Z (about 1 month ago)
- Language: C#
- Homepage:
- Size: 112 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# NTDLS.ExpressionParser
📦 Be sure to check out the NuGet package: https://www.nuget.org/packages/NTDLS.ExpressionParser
ExpressionParser is a mathematics parsing engine for .net. It supports expression nesting, custom variables, custom functions all standard mathematical operations for integer, decimal (floating point), logic and bitwise.
It addition to the custom functions and variables, these are built in: ACOS, ASIN, ATAN, ATAN2, LDEXP, SINH, COSH, TANH, LOG, LOG10, EXP, MODPOW, SQRT, POW, FLOOR, CEIL, NOT, AVG, SUM, TAN, ATAN, SIN, COS, ABS.
👀 If you came for the C++ version you can find it at: https://github.com/NTDLS/CMathParser
👀 Be sure to check out the NuGet package: https://www.nuget.org/packages/NTDLS.ExpressionParser/
## Basic usage:
>**Simple Example:**
>
>In this example we simply call the static function Expression.Evaluate to compute the string expression.
```csharpvar result = Expression.Evaluate("10 * ((1000 / 5 + (10 * 11)))");
Console.WriteLine($"{result:n2}");
```>**Simple Example (with work):**
>
>In this example we simply call the static function Expression.Evaluate to compute the string expression, and we also supply an output parameter for which the parser will use to explain the operations.
```csharpvar result = Expression.Evaluate("10 * ((1000 / 5 + (10 * 11))), out var explanation");
Console.WriteLine($"{result:n2}");
Console.WriteLine(explanation);
```>**Advanced Example:**
>
>In this example we will create an expression that uses two built in functions "Ceil" and "Sum", a custom function called "DoStuff" and one variable called "extra".
```csharpvar expression = new Expression("10 * ((5 + extra + DoStuff(11,55) + ( 10 + !0 )) * Ceil(SUM(11.6, 12.5, 14.7, 11.11)) + 60.5) * 10");
//Add a value for the variable called "extra".
expression.AddParameter("extra", 1000);//Handler for the custom function:
expression.AddFunction("DoStuff", (double[] parameters) =>
{
double sum = 0;
foreach (var parameter in parameters)
{
sum += parameter;
}
return sum;
});var result = ExpressionParser.Evaluate(expression);
Console.WriteLine($"{result:n2}");
```
## License
[MIT](https://choosealicense.com/licenses/mit/)