在工作中基于 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 机制发现实现类,自动安装,实现解偶。
|  |      1pkwenda      2020-05-13 01:41:34 +08:00 看着,如果做财务相关这样用会方便一些,可读性更好,性能方面 [eg:动态编译] 有测试损耗吗? | 
|  |      3w292614191      2020-05-13 08:51:44 +08:00 我们实现了 Excel 公式计算、行列变换、单元格引用计算、函数解析。 | 
|      5xinQing OP @w292614191 我们主要是实现表单公式(比如,表单字段涉及数据变换、依赖),excel 这块到没有涉略噢 |