在类似excel导出功能里,如果excel的格式很复杂,通过程序去动态生成格式显然是很吃力的,我们可以采用模板文件+动态表达式占位来生成目标文件。
如果只是纯粹生成纯文本,使用freemarker等模板解析引擎也可以实现。可以参考我的另外一篇blog:https://www.cnblogs.com/yangzhilong/p/6097211.html
下面这个是SpringEL的简单单元测试类:
import static org.junit.Assert.assertEquals; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import org.junit.Test; import org.springframework.boot.autoconfigure.security.SecurityProperties.User; import org.springframework.expression.EvaluationContext; import org.springframework.expression.ExpressionParser; import org.springframework.expression.spel.standard.SpelExpressionParser; import org.springframework.expression.spel.support.StandardEvaluationContext; public class SpringELTest { @Test public void test2() { Map<String, String> map = new HashMap<>(); map.put("key1", "value1"); User user = new User(); user.setName("zhangsan"); ExpressionParser parser = new SpelExpressionParser(); EvaluationContext context = new StandardEvaluationContext(); context.setVariable("str", "xxx"); context.setVariable("map", map); context.setVariable("user", user); String value = parser.parseExpression("#str").getValue(context, String.class); assertEquals("xxx", value); value = parser.parseExpression("#map.get("key1")").getValue(context, String.class); assertEquals("value1", value); value = parser.parseExpression("#user.name").getValue(context, String.class); assertEquals("zhangsan", value); } }
更多用法可以参考官方文档地址:https://docs.spring.io/spring/docs/3.0.x/reference/expressions.html