在工作中基于 groovy 设计的公式库,希望能带给大家帮助。
公式名(参数)
比如:
ECHO(大侠王波波)
支持公式嵌套:
公式名 1(公式名 2(参数), 参数)
比如:
ECHO(UUID())
下面是例子:
package tk.fishfish.formula;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
/**
* 公式测试
*
* @author 奔波儿灞
* @since 1.0
*/
public class FormulaTest {
private Formula formula;
@Before
public void setup() {
formula = new Formula();
}
@Test
public void lower() {
Object result = formula.run("LOWER(ABC)");
Assert.assertEquals("abc", result);
}
}
这里只是抛砖引玉,实现了如下文本公式:
这里未实现丰富文本、时间、数学、逻辑等公式,只是提供一个扩展机制,方便大家定制自己的公式库。
继承 Plugin 接口
package tk.fishfish.formula.plugin;
import tk.fishfish.formula.annotation.FormulaMapping;
/**
* 自定义公式
*
* @author 奔波儿灞
* @since 1.0
*/
public class CustomPlugin implements Plugin {
/**
* 实现自己的公式
*
* @param name 参数
* @return 结果
*/
@FormulaMapping("ECHO")
public String echo(String name) {
return "echo: " + name;
}
}
自定义方法,增加 @FormulaMapping 注解 映射公式名称
安装插件类,FormulaScript.installPlugin(CustomPlugin.class)
package tk.fishfish.formula;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import tk.fishfish.formula.plugin.CustomPlugin;
import tk.fishfish.formula.script.FormulaScript;
import java.math.BigDecimal;
/**
* 公式测试
*
* @author 奔波儿灞
* @since 1.0
*/
public class FormulaTest {
private Formula formula;
@BeforeClass
public static void init() {
// 安装自己的公式插件
FormulaScript.installPlugin(CustomPlugin.class);
}
@Before
public void setup() {
formula = new Formula();
}
@Test
public void plugin() {
Object result = formula.run("ECHO(xxx)");
System.out.println(result);
}
}
注意:
除了可以手动 FormulaScript.installPlugin(CustomPlugin.class) 安装自定义公式以外,还能通过 SPI 注册。
在 src/main/resources/META-INF/services 目录下创建名称为 tk.fishfish.formula.plugin.Plugin 的文件,里面是实现类的全类名:
# custom plugin
tk.fishfish.formula.plugin.CustomPlugin
此时,会自动通过 SPI 机制发现实现类,自动安装,实现解偶。
1
pkwenda 2020-05-13 01:41:34 +08:00
看着,如果做财务相关这样用会方便一些,可读性更好,性能方面 [eg:动态编译] 有测试损耗吗?
|
3
w292614191 2020-05-13 08:51:44 +08:00
我们实现了 Excel 公式计算、行列变换、单元格引用计算、函数解析。
|
5
xinQing OP @w292614191 我们主要是实现表单公式(比如,表单字段涉及数据变换、依赖),excel 这块到没有涉略噢
|