每周一个Github项目【第二期】govaluate

zablog.me · · 1863 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

golang环境下任意表达式的求值 // Arbitrary expression evaluation for golang

名称 govaluate
地址 Github
作者 Knetic等
brief intro Arbitrary expression evaluation for golang
简要介绍 golang环境下任意表达式的求值
LICENSE MIT
Stars 245

govaluate提供了任意类似C语言的算术/字符串表达式的求值。

为什么你不应该直接在代码中书写表达式

有些时候,你并没有办法提前得知表达式的样子,或者你希望表达式可设置。如果你有一堆运行在你的应用上的数据,或者你想要允许你的用户自定义一些内容,或者你写的是一个监控框架,可以获得很多metrics信息,然后进行一些公式计算,那么这个库就会非常有用。

如何使用

可以创建一个新的EvaluableExpression,然后调用它的”Evaluate”方法。

1
2
3
expression, err := govaluate.NewEvaluableExpression("10 > 0");
result, err := expression.Evaluate(nil);
// result is now set to "true", the bool value.

那么,如何使用参数?

1
2
3
4
5
6
7
expression, err := govaluate.NewEvaluableExpression("foo > 0");
parameters := make(map[string]interface{}, 8)
parameters["foo"] = -1;
result, err := expression.Evaluate(parameters);
// result is now set to "false", the bool value.

这很棒,但是这些基本上可以使用代码直接实现。那么如果计算中牵扯到一些数学计算呢?

1
2
3
4
5
6
7
8
expression, err := govaluate.NewEvaluableExpression("(requests_made * requests_succeeded / 100) >= 90");
parameters := make(map[string]interface{}, 8)
parameters["requests_made"] = 100;
parameters["requests_succeeded"] = 80;
result, err := expression.Evaluate(parameters);
// result is now set to "false", the bool value.

上述例子返回的都是布尔值,事实上,它是可以返回数字的。

1
2
3
4
5
6
7
8
expression, err := govaluate.NewEvaluableExpression("(mem_used / total_mem) * 100");
parameters := make(map[string]interface{}, 8)
parameters["total_mem"] = 1024;
parameters["mem_used"] = 512;
result, err := expression.Evaluate(parameters);
// result is now set to "50.0", the float64 value.

你也可以做一些日期的转化,只要符合RF3339,ISO8061,Unix Date,或者ruby日期格式标准即可。如果你还是不太确定,那么可以看一下支持的日期标准

1
2
3
4
expression, err := govaluate.NewEvaluableExpression("'2014-01-02' > '2014-01-01 23:59:59'");
result, err := expression.Evaluate(nil);
// result is now set to true

表达式只需要进行一次句法分析,就可以多次复用。

1
2
3
4
5
6
7
expression, err := govaluate.NewEvaluableExpression("response_time <= 100");
parameters := make(map[string]interface{}, 8)
for {
parameters["response_time"] = pingSomething();
result, err := expression.Evaluate(parameters)
}

关于执行顺序,本库支持正常C标准的执行顺序。编写表达式时,请确保您正确地书写操作符,或使用括号来明确表达式的哪些部分应先运行。

govaluate采用\或者[]来完成转义。

支持自定义函数

支持简单的结构体(访问器)

运算符支持

ruleplatform的表达式引擎支持以下运算:
二元计算符 : + - / & | ^ * % >> <<
二元比较符 : > >= < <= == != =~ !~
逻辑操作符 : || &&
括号 : ( )
数组相关 : , IN (例子1 IN (1, 2, ‘foo’),返回值true)
一元计算符 : ! - ~
三元运算符 : ? :
空值聚合符: ??

更多内容请查看https://github.com/Knetic/govaluate


有疑问加站长微信联系(非本文作者)

本文来自:zablog.me

感谢作者:zablog.me

查看原文:每周一个Github项目【第二期】govaluate

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1863 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传
X
登录和大家一起探讨吧