
在工作中基于 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 这块到没有涉略噢 |