导入Excel时异常:java.lang.RuntimeException: CountryRecord not found 解决

当遇到Java运行时异常'CountryRecord not found'时,问题可能源于Excel缺少国家码。通过使用Spire.xls.free库,设置Excel文件属性后再保存,可以修复此问题。首先在Maven中添加Spire.xls.free依赖和对应仓库,然后在代码中加载Excel,设置作者属性并保存。经过此处理后的Excel文件能够正常导入。
摘要由CSDN通过智能技术生成

导入Excel时异常:java.lang.RuntimeException: CountryRecord not found
产生此异常原因:使用工具导出Excel时,无国家码。如果将Excel在本地打开,稍微调整格式,不做内容修改,然后保存,再导入发现又恢复正常。
解决方案使用:使用spire.xls.free添加文件属性,然后再保存
添加Maven依赖:

<dependency>
    <groupId>e-iceblue</groupId>
    <artifactId>spire.xls.free</artifactId>
    <version>2.2.0</version>
</dependency>

添加repositories

<repositories>
  <repository>
       <id>com.e-iceblue</id>
       <url>http://repo.e-iceblue.cn/repository/maven-public/</url>
   </repository>
</repositories>

上代码

package com.icanits;

import cn.afterturn.easypoi.excel.ExcelImportUtil;
import cn.afterturn.easypoi.excel.entity.ImportParams;
import cn.afterturn.easypoi.excel.entity.result.ExcelImportResult;
import com.icanits.springbootexample.SpringbootExampleApplication;
import com.icanits.springbootexample.entity.P1XlsReqEntity;
import com.spire.xls.Workbook;
import lombok.extern.slf4j.Slf4j;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import java.io.File;
import java.util.List;

@Slf4j
@RunWith(SpringRunner.class)
@SpringBootTest(classes = SpringbootExampleApplication.class)
public class EasyPoiTest {
    @Test
    public void testImport() throws Exception {
        File importFile = new File(
                "C:\\Users\\Administrator\\Desktop\\P00001C103094200001520220615001.xls");
        Workbook workbook = new Workbook();
        workbook.loadFromFile(importFile.getAbsolutePath());
        //给文件设置属性,相当于修改文件。
        workbook.getDocumentProperties().setAuthor("PENGSIWEN");
        File saveFile = new File("C:\\Users\\Administrator\\Desktop\\P00001C103094200001520220615001_.xls");
        workbook.saveToFile(saveFile.getAbsolutePath());
        ImportParams importParams = new ImportParams();
        importParams.setTitleRows(0);
        importParams.setHeadRows(1);
        importParams.setNeedVerify(true);
        ExcelImportResult<P1XlsReqEntity> objectExcelImportResult =
                ExcelImportUtil.importExcelMore(importFile, P1XlsReqEntity.class, importParams);
        if(objectExcelImportResult.isVerfiyFail()){
            List<P1XlsReqEntity> failList = objectExcelImportResult.getFailList();
            for (P1XlsReqEntity p1XlsReqEntity : failList) {
                System.out.println("--- 第"+p1XlsReqEntity.getRowNum()+"行错误:" + p1XlsReqEntity.getErrorMsg());
            }
        }
    }
}

问题完美解决!!!

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
根据提供的引用内容,你遇到了一个运行异常:Caused by: java.lang.RuntimeException: java.lang.ClassNotFoundException: Cannot find implementation。这个异常通常是由于找不到某个类的实现导致的。解决这个问题的方法有以下几种: 1. 检查依赖项:首先,确保你的项目中包含了所需的依赖项。在Android开发中,你可以在项目的build.gradle文件中添加所需的依赖项。例如,如果你使用的是Gradle构建工具,你可以在dependencies部分添加所需的库。然后,重新构建你的项目并运行它。 2. 检查类路径:如果你确定依赖项已经正确添加到项目中,那么可能是类路径的问题。类路径是指Java虚拟机(JVM)用来查找类文件的路径。确保你的类路径包含了所需的类文件。你可以通过在命令行中使用java命令的-cp选项来指定类路径。例如,如果你的类文件位于一个名为lib的文件夹中,你可以使用以下命令来运行你的应用程序: ```shell java -cp lib/ YourMainClass ``` 3. 检查类名和包名:如果你确定依赖项和类路径都没有问题,那么可能是类名或包名的问题。确保你在代码中正确引用了类名和包名。检查你的import语句和类的全限定名是否正确。 4. 清除缓存和重新构建:有候,清除构建缓存并重新构建项目可以解决一些奇怪的问题。你可以尝试清除你的项目的构建缓存,并重新构建它。 5. 检查编译版本:如果你在使用某个库或框架遇到了这个问题,确保你的编译版本与该库或框架的要求相匹配。有候,不同的库或框架需要特定的编译版本才能正常工作。 这些是解决Caused by: java.lang.ClassNotFoundException: Cannot find implementation异常的一些常见方法。根据你的具体情况,你可以尝试其中的一种或多种方法来解决问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值