通过excel导入数据

1.引入依赖

XML 复制代码
 <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>5.2.5</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>5.2.5</version>
        </dependency>
        <!--&lt;!&ndash; Poi-tl Word 模板引擎&ndash;&gt;-->
        <dependency>
            <groupId>com.deepoove</groupId>
            <artifactId>poi-tl</artifactId>
            <version>1.12.2</version>
        </dependency>

示例代码

java 复制代码
public List<Item> importItem(InputStream inputStream) throws IOException {

    Workbook wb = new XSSFWorkbook(inputStream);
    String[] titles = new String[]{"学号","姓名","性别"};
    try {
        Sheet sheet = wb.getSheet(0);
        Row titleRow = sheet.getRow(1);
        Map<String,String> rowData = getRowData(titleRow,titles);
        
for(String k:rowData.keySet()){
    String v = rowData.get(k);
if(!k.equals(v)){
    throw new RuntimeException(String.format("错误的列标题:%s,导入失败!",v));
}
}

List<Item> items = new LinkedList<>();
int rows = sheet.getPhysicalNumberOfRows();
for(int j = 2; j < rows; j++){
    Row row = sheet.getRow(j);
Map<String,String> data = getRowData(row,titles);
if(data.size()>0){
Item item = new Item();
try{
    item.setStudentId(data.get(titles[0]).trim());
    item.setName(data.get(titles[1]).trim());
    item.setSex(data.get(titles[2]).trim());


}catch(Exception e){
throw new RuntimeException(String.format("第%s,导入失败,请检查数据!",j+1));
}
items.add(item);

}


}

return new HashMap<>(){{
put("items", items);
}};

}catch(Exception e){
    throw new RuntimeException(e.getMessage());
}


}

public static Map<String,String> getRowData(Row row,String[] titles){

    if(null == row || isRowEmpty(row)){
    return new HashMap<>();
}

int cells = titles.length;
Map<String,String> data = new LinkedHashMap<>();
for(int i = 0; i < cells; i++){
Cell cell = row.getCell(i);
if(cell == null || isEmpty(cell.toString())){

    data.put(titles[i],"");

}else{

switch(cell.getCellType()){
    case NUMERIC:
        DecimalFormat df = new DecimalFormat("0.############");

        String s = df.format(cell.getNumericCellValue());
        data.put(titles[i],s);
        break;
    case STRING:
        data.put(titles[i],cell.getStringCellValue());
        break;
    case BLANK:
        data.put(titles[i],"");
        break;
    case BOOLEAN:
        data.put(titles[i],Boolean.valueOf(cell.getBooleanCellValue()).toString());
        break;
    case FORMULA:
        data.put(titles[i],cell.getRichStringCellValue().toString());
        break;
    default:
        data.put(titles[i],cell.toString());
        break;

}


}


}

return data;

}


public static boolean isRowEmpty(Row row) {

    if(null == row){
    return true;
}
for(int i = row.getFirstCellNum(); i < row.getLastCellNum(); i++){
    Cell cell = row.getCell(i);
    
if(cell != null && cell.getCellType != CellType.BLANK)
    return false;

}
return true;


}


public static boolean isEmpty(String str){
    if(Objects.isNull(str)){
        return true;
}else{
    return str.trim().length() == 0;
}


}
相关推荐
两袖清风99814 分钟前
【Java】—— 常见的排序算法
java·数据结构·算法·排序算法
重生之后端学习18 分钟前
06-Web后端基础(java操作数据库)
java·开发语言·数据库·后端·中间件·jdbc
柒七爱吃麻辣烫24 分钟前
npm修改镜像的教程,将npm镜像修改为国内地址增加下载速度
java·前端·npm·node.js·vue
走过冬季32 分钟前
LinkedList 与 ArrayList 的区别及使用场景
java
小鸡脚来咯44 分钟前
MVCC实现原理
java·开发语言·数据库
小鹭同学_1 小时前
Java基础 Day20
java·开发语言
浩浩测试一下1 小时前
Apache OFBiz 17.12.01 的远程命令执行漏洞 -Java 反序列化 + XML-RPC 请求机制
xml·java·安全·web安全·网络安全·apache·安全架构
Smilecoc1 小时前
数据透视表和公式法在Excel中实现去除重复计数的方法
excel
27669582922 小时前
开盘啦 APP 抓包 逆向分析
java·python·app抓包·抓包分析·开盘啦
啥都想学的又啥都不会的研究生2 小时前
log日志最佳实践
java·spring boot·后端·spring·junit·log4j·logback