FunctionX 0.1.6
See the version list below for details.
dotnet add package FunctionX --version 0.1.6
NuGet\Install-Package FunctionX -Version 0.1.6
<PackageReference Include="FunctionX" Version="0.1.6" />
paket add FunctionX --version 0.1.6
#r "nuget: FunctionX, 0.1.6"
// Install FunctionX as a Cake Addin #addin nuget:?package=FunctionX&version=0.1.6 // Install FunctionX as a Cake Tool #tool nuget:?package=FunctionX&version=0.1.6
FunctionX
The FunctionX library implements Excel-like formula features in C#. It allows users to manipulate data in ways similar to Excel formulas. The library utilizes the NCalc library for evaluating expressions and supports complex data types to perform various operations.
Features
The FunctionX library offers the following features:
Usage
To use the FunctionX library:
- Call the
Fx.Evaluate
method to evaluate a formula. - Pass the formula string and a dictionary of parameters.
Examples
Here are some examples of using the FunctionX library:
// Basic mathematical operation
var result = await Fx.EvaluateAsync("1 + 2 + 3");
// Calculate the average value in an array
var parameters = new Dictionary<string, object?>
{
{ "myArray", new object[] {1, 2, 3, 4, 5} }
};
var average = await Fx.EvaluateAsync("AVERAGE(@myArray)", parameters);
// Conditional logic
var parameters = new Dictionary<string, object?>
{
{ "value1", 10 },
{ "value2", 20 }
};
var ifResult = await Fx.EvaluateAsync("IF(@value1 > @value2, \"Yes\", \"No\")", parameters);
Implemented Functions
Function Name | Description |
---|---|
SUM |
Calculates the sum of numeric values. |
AVERAGE |
Calculates the average of numeric values. |
MAX |
Finds the maximum value among numeric values. |
MIN |
Finds the minimum value among numeric values. |
COUNT |
Counts the number of numeric values. |
COUNTA |
Counts the number of non-empty values. |
AND |
Returns true if all values are true. |
OR |
Returns true if at least one value is true. |
NOT |
Returns true if the value is false. |
XOR |
Returns true if an odd number of values are true. |
IF |
Returns one of two values depending on a condition. |
IFS |
Returns the result of the first true condition among multiple conditions. |
SWITCH |
Returns a value based on given cases or provides a default value. |
CONCAT |
Concatenates string values. |
LEFT |
Returns a specified number of characters from the beginning of a string. |
RIGHT |
Returns a specified number of characters from the end of a string. |
MID |
Returns a specified number of characters from a string starting at a specified position. |
TRIM |
Removes leading and trailing whitespace from a string. |
UPPER |
Converts a string to uppercase. |
LOWER |
Converts a string to lowercase. |
PROPER |
Converts the first letter of each word in a string to uppercase. |
REPLACE |
Replaces occurrences of a specified substring within a string with another substring. |
LEN |
Returns the length of a string. |
INDEX |
Returns the value at a specified position in an array or dictionary. |
VLOOKUP |
Searches for a value in the first column of a range and returns a value in the same row from a specified column. |
UNIQUE |
Returns an array of unique values with duplicates removed. |
Installation
This library is not currently available via NuGet. To use the library, you will need to download the source code directly and include it in your project.
Requirements
- netstandard2.1
Contributing
FunctionX is an open-source project. If you would like to contribute, please send a pull request or file an issue.
License
The FunctionX library is provided under the MIT license.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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 was computed. 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. |
.NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.1 is compatible. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.1
- Microsoft.CodeAnalysis.CSharp.Scripting (>= 4.9.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.