在相似excel導出功能裏,若是excel的格式很複雜,經過程序去動態生成格式顯然是很吃力的,咱們能夠採用模板文件+動態表達式佔位來生成目標文件。html
若是隻是純粹生成純文本,使用freemarker等模板解析引擎也能夠實現。能夠參考個人另一篇blog:http://www.javashuo.com/article/p-pekpllio-hw.htmljava
下面這個是SpringEL的簡單單元測試類:spring
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.htmlexpress