计算

因软件更新较快,部分文档内容与软件最新版本有所出入,请知悉。

简介

用于将一段文本内容作为计算公式或表达式进行解析计算。例如:

  • 3*5+20  (结果为35)
  • 15>6    (结果为True)

image.png


可以结合插值语法将变量的值替换到表达式中。例如表达式为:“$$  {变量a} > 5 and {变量a} < 20” ,如果 变量a 的值为 30,那么表达式在插值后变为“30 > 5 and 30 < 20” ,其结果为false。(插值后得到文本表达式,然后计算这个表达式得到最终结果)


参数

输入参数

【表达式】表示需要计算的数学公式。

【增强模式】强模式支持变量和C#语言的Math类。


输出

【结果】计算结果。


普通模式与增强模式


普通模式

这个模块在内部使用了NCalc组件,您也可以参考这个组件的文档以了解这个模块可以实现的功能。


示例

  • 类型转换
    • $${含有数字的文本变量}   =>  转换为数字
    • $$ '{数字}'     =>  转换为文本
  • 判断
    • $$ {变量} > 5 and {变量} < 30
    • $$ {变量} * 5 < 20
    • $$ {变量1} > {变量2}             => 判断 变量1 和 变量2 的大小关系
  • 计算
    • 50 * 2 * Sqrt(40)
    • Min(1,2)


以下内容有部分转载自 tangikejun的文章,感谢!

普通模式支持的运算符

  1. 原子运算符 ()
  2. 单目运算符 !not-~(按位取反)
  3. 幂次运算符 (原文作者遗漏了,他写了位运算符 &|^(xor), <<>> )
  4. 乘除运算符 */%
  5. 加减运算符 +-
  6. 关系运算符 ===!=<><<=>>=
  7. 逻辑运算符 or,||,and,&&

普通模式支持的函数

注:结果中的 M 代表 Decimal 类型,d 代表 Double 类型,是不同精度的有理数。

函数名描述用例用例结果
Abs返回绝对值Abs(-1)1M
Acos返回余弦值对应的角度Acos(1)0d
Asin--d
Atan--d
Ceiling向上取整Ceiling(1.5)2d
Cos--d
Exp相当于 e 的 X 次幂Exp(0)1d
Floor向下取整Floor(1.5)1d
IEEERemainderIEEE 754 标准下的取余操作,具体细节自行百度。普通的整数取余数请使用%操作符,如 15 % 7 结果为 1。IEEERemainder(3, 2)-1d
Log以第二个参数为底取对数Log(1,10)0d
Log10以10为底取对数Log10(1)0d
Max-Max(1,2)2
Min-Min(1,2)1
Pow-Pow(3,2)9d
Round第二个参数表示保留几位小数,Round 的舍入规则是“四舍六入五成双”,具体的舍入中间值可以在构造 Expression 对象时用 EvaluateOption.RoundAwayFromZero 设定。Round(3.222,2)3.22d
Sign取符号Sign(-10)-1
Sin--d
Sqrt取平方根Sqrt(4)2d
Tan--d
Truncate截取整数部分Truncate(1.7)1


其他通用函数:

函数名描述用例结果
in判断第一个元素是否在后面的一系列值之中in(1 + 1, 1, 2, 3)true
if类似于 expression ? a:b 。根据表达式结果在后两个参数中选择一个返回if(3 % 2 = 1, 'value is true', 'value is false')'value is true'

自定义函数

将Unix时间戳转换为时间:UnixTimestampToDateTime(1552437663)


增强模式

增强模式可以使用通用表达式相同的语法:https://getquicker.net/kc/help/doc/expression,(不需要在前面写$=,如果写了,会先解析表达式后,把得到的结果再作为表达式解析一遍

image.png



示例动作


使用场景

  • 简单的运算求解,比如计算选中的一个数学算式;
  • 比较数字、文本等,以获得分支条件;
  • 变量类型转换,比如将文本转换成数字等;


反馈与讨论

语雀在语雀上查看