首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jxls -多行(列表)绑定无效

jxls -多行(列表)绑定无效
EN

Stack Overflow用户
提问于 2016-02-15 09:31:42
回答 1查看 1.2K关注 0票数 1

我正在尝试使用jxls库创建excel表单。

我的excel模板是:

当我只添加一张地图来列出并绑定它时,它就能工作了。我的代码很简单:

代码语言:javascript
复制
List<Map<String,Object>> sss = new ArrayList();

HashMap<String,Object> sm = new HashMap<String,Object>();
sm.put("name1", "AtestName");
sm.put("name2", "AtestName2");
sm.put("name3", "AtestName3");
sss.add(sm);

Map<String, Object> model = new HashMap<String,Object>();
model.put("sData", sss);
....  XLSTransformer transformer = new XLSTransformer(); .....

但是,当我添加多个映射来列出并绑定它时,它将失败抛出异常。我听说jxls库自动识别列表。我在做什么?

代码语言:javascript
复制
List<Map<String,Object>> sss = new ArrayList();
HashMap<String,Object> sm = new HashMap<String,Object>();
sm.put("name1", "AtestName");
sm.put("name2", "AtestName2");
sm.put("name3", "AtestName3");
sss.add(sm);

HashMap<String,Object> sm2 = new HashMap<String,Object>();
sm.put("name1", "BtestName");
sm.put("name2", "BtestName2");
sm.put("name3", "BtestName3");
sss.add(sm2);

HashMap<String,Object> sm3 = new HashMap<String,Object>();
sm.put("name1", "CtestName");
sm.put("name2", "CtestName2");
sm.put("name3", "CtestName3");
sss.add(sm3);

Map<String, Object> model = new HashMap<String,Object>();
model.put("sData", sss);
....  XLSTransformer transformer = new XLSTransformer(); .....




[ 06:15:10] DEBUG - AbstractExcelView.renderMergedOutputModel(140) | Created Excel Workbook from scratch
[ 06:15:10] DEBUG - SheetTransformer.transformSheet(72) | Processing sheet: Sheet1
[ 06:15:10] DEBUG - CollectionRowTransformer.processRowCollections(96) | ----collection-property--------->sData
, 2016 6:15:10 오후 org.apache.catalina.core.StandardWrapperValve invoke
: Servlet.service() for servlet action threw exception
java.lang.NoSuchMethodError: org.apache.poi.ss.usermodel.Sheet.getSheetConditionalFormatting()Lorg/apache/poi/ss/usermodel/SheetConditionalFormatting;
    at net.sf.jxls.util.Util.copyConditionalFormat(Util.java:642)
    at net.sf.jxls.util.Util.copyCell(Util.java:569)
    at net.sf.jxls.util.Util.duplicateStyle(Util.java:411)
    at net.sf.jxls.util.Util.duplicateRow(Util.java:244)
    at net.sf.jxls.controller.SheetTransformationControllerImpl.duplicateRow(SheetTransformationControllerImpl.java:140)
    at net.sf.jxls.transformer.CollectionRowTransformer.processRowCollections(CollectionRowTransformer.java:106)
    at net.sf.jxls.transformer.CollectionRowTransformer.transform(CollectionRowTransformer.java:66)
    at net.sf.jxls.transformer.SheetTransformer.transformSheet(SheetTransformer.java:88)
    at net.sf.jxls.transformer.XLSTransformer.transformWorkbook(XLSTransformer.java:248)
    at net.sf.jxls.transformer.XLSTransformer.transformXLS(XLSTransformer.java:221)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-02-15 11:37:24

您得到的java.lang.NoSuchMethodError:org.apache.poi.ss.usermodel.Sheet.getSheetConditionalFormatting错误很可能意味着POI版本有问题。

因此,请检查您使用的Apache版本,以及它是否支持Sheet.getSheetConditionalFormatting()方法。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35405689

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档