解决问题:com.alibaba.excel.exception.ExcelAnalysisException: Can not instance class: xx.xx.xx

红太狼 2021-01-24 03:47 9104阅读 1赞
  1. com.alibaba.excel.exception.ExcelAnalysisException: Can not instance class: com.atguigu.demo.excel.DemoData
  2. at com.alibaba.excel.read.metadata.holder.AbstractReadHolder.notifyEndOneRow(AbstractReadHolder.java:147)
  3. at com.alibaba.excel.analysis.v07.handlers.ProcessResultCellHandler.endHandle(ProcessResultCellHandler.java:44)
  4. at com.alibaba.excel.analysis.v07.XlsxRowHandler.endElement(XlsxRowHandler.java:44)
  5. at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.endElement(AbstractSAXParser.java:609)
  6. at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanEndElement(XMLDocumentFragmentScannerImpl.java:1782)
  7. at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl$FragmentContentDriver.next(XMLDocumentFragmentScannerImpl.java:2967)
  8. at com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(XMLDocumentScannerImpl.java:602)
  9. at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:505)
  10. at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:842)
  11. at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:771)
  12. at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:141)
  13. at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.parse(AbstractSAXParser.java:1213)
  14. at com.sun.org.apache.xerces.internal.jaxp.SAXParserImpl$JAXPSAXParser.parse(SAXParserImpl.java:643)
  15. at com.alibaba.excel.analysis.v07.XlsxSaxAnalyser.parseXmlSource(XlsxSaxAnalyser.java:158)
  16. at com.alibaba.excel.analysis.v07.XlsxSaxAnalyser.execute(XlsxSaxAnalyser.java:182)
  17. at com.alibaba.excel.analysis.ExcelAnalyserImpl.analysis(ExcelAnalyserImpl.java:105)
  18. at com.alibaba.excel.ExcelReader.read(ExcelReader.java:180)
  19. at com.alibaba.excel.ExcelReader.read(ExcelReader.java:170)
  20. at com.alibaba.excel.read.builder.ExcelReaderSheetBuilder.doRead(ExcelReaderSheetBuilder.java:160)
  21. at com.atguigu.demo.excel.TestEasyexcel.testread(TestEasyexcel.java:33)
  22. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  23. at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
  24. at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  25. at java.lang.reflect.Method.invoke(Method.java:498)
  26. at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
  27. at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
  28. at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
  29. at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
  30. at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
  31. at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
  32. at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
  33. at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
  34. at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
  35. at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
  36. at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
  37. at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
  38. at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
  39. at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
  40. at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68)
  41. at com.intellij.rt.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:33)
  42. at com.intellij.rt.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:230)
  43. at com.intellij.rt.junit.JUnitStarter.main(JUnitStarter.java:58)
  44. Caused by: com.alibaba.excel.exception.ExcelDataConvertException: Can not instance class: com.atguigu.demo.excel.DemoData
  45. at com.alibaba.excel.read.listener.ModelBuildEventListener.buildUserModel(ModelBuildEventListener.java:98)
  46. at com.alibaba.excel.read.listener.ModelBuildEventListener.invoke(ModelBuildEventListener.java:38)
  47. at com.alibaba.excel.read.listener.ModelBuildEventListener.invoke(ModelBuildEventListener.java:28)
  48. at com.alibaba.excel.read.metadata.holder.AbstractReadHolder.notifyEndOneRow(AbstractReadHolder.java:141)
  49. ... 41 more
  50. Caused by: java.lang.InstantiationException: com.atguigu.demo.excel.DemoData
  51. at java.lang.Class.newInstance(Class.java:427)
  52. at com.alibaba.excel.read.listener.ModelBuildEventListener.buildUserModel(ModelBuildEventListener.java:94)
  53. ... 44 more
  54. Caused by: java.lang.NoSuchMethodException: com.atguigu.demo.excel.DemoData.<init>()
  55. at java.lang.Class.getConstructor0(Class.java:3082)
  56. at java.lang.Class.newInstance(Class.java:412)
  57. ... 45 more
  • 问题描述:在使用easyExcel时,进行读操作,出现如上错误。
  • 解决思考:

    • 分析:在上述报错信息中,我们关注下面四句输出信息

    ExcelAnalysisException: Can not instance class: com.atguigu.demo.excel.DemoData
    ExcelDataConvertException: Can not instance class: com.atguigu.demo.excel.DemoData
    InstantiationException: com.atguigu.demo.excel.DemoData
    NoSuchMethodException: com.atguigu.demo.excel.DemoData.()

  1. 四句话都有DemoData,不难分析出来该类有问题
  2. 其次, Can not instance class,不能实例化,可以推出构造方法有问题
  3. 最后一句:NoSuchMethodException没有此方法,得出缺少无参构造方法
  4. 定位到该类,发现确实没有无参构造

    @Data
    @AllArgsConstructor
    public class DemoData {

    • 解决方法

添加无参构造:例如
加上该注解@NoArgsConstructor

  1. @Data
  2. @AllArgsConstructor
  3. @NoArgsConstructor
  4. public class DemoData {

或者自己写上无参构造

  1. public DemoData(){ }

发表评论

表情:
评论列表 (有 0 条评论,9104人围观)

还没有评论,来说两句吧...

相关阅读