Java(119):ExcelUtil工具类(org.apache.poi读取和写入Excel)

news2025/1/22 19:38:36

ExcelUtil工具类(XSSFWorkbook读取和写入Excel),入参和出参都是:List<Map<String,Object>>

一、读取Excel

testdata.xlsx


1、new XSSFWorkbook对象

            File file = new File(filePath);
            FileInputStream fis = new FileInputStream(file);
            XSSFWorkbook wb = new XSSFWorkbook(fis);


2、new XSSFSheet对象

            //获取sheet第一个
            XSSFSheet xSheet = wb.getSheetAt(0);
            if(sheetName!=null) {
                //如果sheetName入参可用这个,通过名称获取
                xSheet = wb.getSheet(sheetName);
            }


3、遍历行读取数据写入List<Map<String,Object>>

          for (int i = 0; i <= xSheet.getLastRowNum(); i++) {  //遍历所有行
                if(i==0){  //标题行
                    for (int j = 0; j < xSheet.getRow(i).getPhysicalNumberOfCells(); j++) {
                        headMap.put(j, xSheet.getRow(i).getCell(j).toString());
                    }
                    continue;
                }
                Map<String, Object> paramsMap = new HashMap<>();
                for (int j = 0; j < xSheet.getRow(i).getPhysicalNumberOfCells(); j++) {  //遍历当前行所有列
                    String key=headMap.get(j);
                    Cell cell=xSheet.getRow(i).getCell(j);
                    switch (cell.getCellType()) {
                        case Cell.CELL_TYPE_STRING:
                            paramsMap.put(key,cell.getStringCellValue());
                            break;
                        case Cell.CELL_TYPE_NUMERIC:
                            paramsMap.put(key,new Double(cell.getNumericCellValue()).intValue());
                            break;
                    }
                    //paramsMap.put(key,xSheet.getRow(i).getCell(j));
                }
                resultList.add(paramsMap);
            }

二、写入Excel


1、XSSFWorkbook  创建一个工作蒲

        XSSFWorkbook xwb = new XSSFWorkbook();
        XSSFSheet  sheet = xwb.createSheet(sheetName);

2、XSSFSheet写入标题行

        XSSFRow row = sheet.createRow(0);
        for (int i=0;i<listHead.size();i++){
            //根据需要给第一行每一列设置标题
            XSSFCell cell = row.createCell(i);
            cell.setCellValue(listHead.get(i));
        }

3、数据赋值并设置列


        //创建行
        XSSFRow rows;
        //创建列,即单元格Cell
        XSSFCell cells;

        //把List里面的数据写到excel中(除标题行外)
        for (int i=0;i<listA.size();i++) {
            //从第一行开始写入
            rows = sheet.createRow(i + 1);
            //创建每个单元格Cell,即列的数据
            Map<String, Object> testMap =listA.get(i);
            for (int j=0;j<listHead.size();j++){
                cells = rows.createCell(j);
                String head=listHead.get(j);
                String type=testMap.get(head).getClass().getTypeName();
                switch (type) {
                    case "java.lang.Integer":
                        cells.setCellValue((int) testMap.get(head));
                        break;
                    case "java.lang.String":
                        cells.setCellValue((String) testMap.get(head));
                        break;
                }
            }
        }

4、写入excel

            File file = new File(filePath);
            FileOutputStream outputStream = new FileOutputStream(file);
            xwb.write(outputStream);
            outputStream.flush();
            outputStream.close();

result.xlsx


三、整体工具类(参考)

package com.example.utils;

import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.*;

/**
 * Description :
 *
 * @author : HMF
 * Date : Created in 10:40 2023/11/23
 * @version :
 */
public class ExcelUtil {

    /**
     * 读取excel,放入List<Map<String, String>>
     * @param filePath 读取excel的文件路径+文件名称
     * @return datalist
     */
    public static List<Map<String,Object>> readExcel(String filePath){
        return readExcel(filePath,null);
    }

    /**
     * 读取excel,放入List<Map<String, String>>
     * @param filePath 读取excel的文件路径+文件名称
     * @Param sheetName sheet名称
     * @return datalist
     */
    public static List<Map<String,Object>> readExcel(String filePath,String sheetName){
        List<Map<String,Object>> resultList = new ArrayList<>();
        Map<Integer, String> headMap = new HashMap<>();
        try {
            File file = new File(filePath);
            FileInputStream fis = new FileInputStream(file);
            XSSFWorkbook wb = new XSSFWorkbook(fis);
            //获取sheet第一个
            XSSFSheet xSheet = wb.getSheetAt(0);
            if(sheetName!=null) {
                //如果sheetName入参可用这个,通过名称获取
                xSheet = wb.getSheet(sheetName);
            }
            for (int i = 0; i <= xSheet.getLastRowNum(); i++) {  //遍历所有行
                if(i==0){  //标题行
                    for (int j = 0; j < xSheet.getRow(i).getPhysicalNumberOfCells(); j++) {
                        headMap.put(j, xSheet.getRow(i).getCell(j).toString());
                    }
                    continue;
                }
                Map<String, Object> paramsMap = new HashMap<>();
                for (int j = 0; j < xSheet.getRow(i).getPhysicalNumberOfCells(); j++) {  //遍历当前行所有列
                    String key=headMap.get(j);
                    Cell cell=xSheet.getRow(i).getCell(j);
                    switch (cell.getCellType()) {
                        case Cell.CELL_TYPE_STRING:
                            paramsMap.put(key,cell.getStringCellValue());
                            break;
                        case Cell.CELL_TYPE_NUMERIC:
                            paramsMap.put(key,new Double(cell.getNumericCellValue()).intValue());
                            break;
                    }
                    //paramsMap.put(key,xSheet.getRow(i).getCell(j));
                }
                resultList.add(paramsMap);
            }

        }catch (IOException e){
            System.out.println(e);
        }
        return resultList;

    }

    /**
     * 写入excel
     * @param filePath 读取excel的文件路径+文件名称
     * @Param sheetName sheet名称
     * @param listA  入参列表
     * @param listHead 标题头列表
     */
    public static void writeExcel(String filePath, String sheetName, List<Map<String, Object>> listA,List<String> listHead){

        XSSFWorkbook xwb = new XSSFWorkbook();
        XSSFSheet  sheet = xwb.createSheet(sheetName);

        //标题行
        XSSFRow row = sheet.createRow(0);
        for (int i=0;i<listHead.size();i++){
            //根据需要给第一行每一列设置标题
            XSSFCell cell = row.createCell(i);
            cell.setCellValue(listHead.get(i));
        }

        //创建行
        XSSFRow rows;
        //创建列,即单元格Cell
        XSSFCell cells;

        //把List里面的数据写到excel中(除标题行外)
        for (int i=0;i<listA.size();i++) {
            //从第一行开始写入
            rows = sheet.createRow(i + 1);
            //创建每个单元格Cell,即列的数据
            Map<String, Object> testMap =listA.get(i);
            for (int j=0;j<listHead.size();j++){
                cells = rows.createCell(j);
                String head=listHead.get(j);
                String type=testMap.get(head).getClass().getTypeName();
                switch (type) {
                    case "java.lang.Integer":
                        cells.setCellValue((int) testMap.get(head));
                        break;
                    case "java.lang.String":
                        cells.setCellValue((String) testMap.get(head));
                        break;
                }
            }
        }

        //用输出流写到excel
        try {
            File file = new File(filePath);
            FileOutputStream outputStream = new FileOutputStream(file);
            xwb.write(outputStream);
            outputStream.flush();
            outputStream.close();
        }catch (IOException e) {
            e.printStackTrace();
        }

    }



    public static void main(String args[]){
        String filePath="src/main/resources/testdata.xlsx";
        List<Map<String, Object>> resultList= readExcel(filePath,"Sheet1");
        for(Map<String, Object> testMap:resultList){
            System.out.println(testMap);
//            for(String excKey :testMap.keySet()){
//                System.out.println(excKey+": "+testMap.get(excKey));
//            }
        }


        List<String> listHead =new ArrayList<>();
        listHead.add("id");
        listHead.add("name");
        listHead.add("age");
        listHead.add("grade");

        writeExcel("src/main/resources/result.xlsx","result",resultList,listHead);


    }


}

参考:https://www.cnblogs.com/janson071/p/10119935.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1259117.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

TikTok数据分析:如何通过数字洞察提升内容质量?

引言 TikTok作为全球最热门的短视频平台之一&#xff0c;每天吸引着亿万用户发布和观看各类内容。在这个充满创意的舞台上&#xff0c;内容质量成为吸引关注和提高曝光度的关键。 而要达到这一目标&#xff0c;数字数据分析成为不可或缺的工具。本文将深入探讨如何通过TikTok数…

高端制造业中的通用性超精密3D光学测量仪器

超精密光学3D测量仪器具有高精度、自动化程度高、实时反馈和范围广等优势。它能够实现微米级别的精确测量&#xff0c;能够精确测量产品的尺寸、形状和表面粗糙度等&#xff0c;具有广泛的应用价值和重要意义。 超精密光学3D测量仪器配备多种传感器、控制器和计算机系统&#…

Docker智驾开发环境搭建

文章目录 背景1. 什么是容器?2. 什么是Docker?2.1 Docker架构3. 为什么要使用Docker?3.1 Docker容器虚拟化的好处3.2 Docker在开发和运维中的优势4. Docker容器与传统虚拟化的区别4.1 区别4.2 Docker的优势5. Docker的核心概念6. Docker在嵌入式开发中的应用7. docker实践参…

企业网络中的身份安全

随着近年来数字化转型的快速发展&#xff0c;企业使用的数字身份数量急剧增长。身份不再仅仅局限于用户。它们现在扩展到设备、应用程序、机器人、第三方供应商和组织中员工以外的其他实体。即使在用户之间&#xff0c;也存在不同类型的身份&#xff0c;例如属于IT管理员、远程…

IDEA中也能用postman了?

Postman是大家最常用的API调试工具&#xff0c;那么有没有一种方法可以不用手动写入接口到Postman&#xff0c;即可进行接口调试操作&#xff1f;今天给大家推荐一款IDEA插件&#xff1a;Apipost Helper&#xff0c;写完代码就可以调试接口并一键生成接口文档&#xff01;而且还…

OpenHarmony模块化编译

一、环境配置 OpenHarmony版本&#xff1a;OpenHarmony 4.0 Release 编译环境&#xff1a;WSL2 Ubuntu 18.04 平台设备&#xff1a;RK3568 二、配置hb OpenHarmony 代码构建有build.sh和hb两种方式: #方式一、build.sh ./build.sh --product-name rk3568 --ccache#方式二、…

CSC公派博士后|管理学老师赴韩国首尔大学达成目标

J老师自身背景正好卡在CSC公派博士后申报条件的边缘&#xff0c;为增大通过概率&#xff0c;其提出优选亚洲范围内的世界知名高校、专业相符、2年博士后职位的要求。最终我们用韩国首尔大学的邀请函助其顺利获批CSC&#xff0c;实现了所有既定目标。 J老师背景&#xff1a; 申…

Linux使用固定ip地址

设置静态ip&#xff0c;我们就需要修改 /etc/sysconfig/network-scripts/ifcfg-ens33 配置文件。 vim /etc/sysconfig/network-scripts/ifcfg-ens33 //进入网卡ens33的配置页面 (1) 将 BOOTPROTO dhcp 改成 BOOTPROTO static 也就是将动态ip&#xff0c;改成静态i…

【Java Spring】SpringBoot常用插件

文章目录 1、Lombok1.1 IDEA社区版安装Lombok1.2 IDEA专业版安装Lombok1.3 Lombok的基本使用 2、EditStarters2.1 IDEA社区版安装EditStarters2.2 IDEA专业版安装EditStarters2.3 EditStarters基本使用方法 1、Lombok 是简化Java开发的一个必要工具&#xff0c;lombok的原理是…

腾讯云优惠券如何领取(腾讯云在哪领取优惠券)

腾讯云作为国内领先的云计算服务提供商&#xff0c;一直致力于为用户提供优质、高效、安全的云计算服务。为了吸引广大用户&#xff0c;腾讯云经常推出各种优惠活动&#xff0c;其中就包括优惠券的发放。那么&#xff0c;腾讯云优惠券如何领取呢&#xff1f;本文将为大家详细解…

虚幻学习笔记—点击场景3D物体的两种处理方式

一、前言 本文使用的虚幻引擎为5.3.2&#xff0c;两种方式分别为&#xff1a;点击根物体和精准点击目标物体。 二、实现 2.1、玩家控制器中勾选鼠标点击事件&#xff1a;这一步很重要&#xff0c;如图2.1.1所示&#xff1a;在自定义玩家控制器中勾 图2.1.1 选该项&#xff0c…

CentOS7.9虚拟机EDA环境,支持模拟集成电路、数字集成电路、数模混合设计全流程,包含工艺库

目录 前言一、配置准备工作1.1 网盘文件说明1.2 EDA工具介绍 二、虚拟机运行2.1 虚拟机工具启动2.2 软件配置使用2.3 Module工具切换环境变量和软件版本 获取方法附录&#xff1a;部分EDA工具运行效果图 前言 搭建了CentOS7.9虚拟机环境&#xff0c;工具包括但不限于&#xff…

静态方法和属性的经典使用-单例设计模式

单例设计模式 一、设计模式二、单例模式1、饿汉式2、懒汉式3、区别 单例设计模式是静态方法和属性的经典使用。 一、设计模式 设计模式是在大量的实践中总结和理论化之后优选的代码结构、编程风格、以及解决问题的思考方式。设计模式就像是经典的棋谱&#xff0c;不同的棋局&…

uniapp基础-教程之HBuilderX基础常识篇02

uniapp创建项目时属性多为vue后缀&#xff1b;其中每个文件中都包含了三段式结构分别是template&#xff1b;script&#xff1b;style形势&#xff0c;分别是前端显示的画面以及js和css样式。 template&#xff1a;说大白话就是给别人看的&#xff0c;我们打开页面就可以看到的…

程序员必备的学习工具,建议收藏!

作为一名刚入门的程序员&#xff0c;选择合适的开发工具可以提高工作效率&#xff0c;加快学习进度。在一个劳动力追求高性价的时代, 我们无时无刻不在追寻更高的工作学习效率&#xff0c;在本文中&#xff0c;我将向您推荐一些常用的好用工具。 01 搜索资源网站 学习技术过程…

软件测试中设定优先级、做好风险管理很重要

一、为什么重要&#xff1f; 1. 资源有限 测试资源如时间、人员、设备等总是有限的&#xff0c;确定优先级可以确保最重要的功能得到足够的关注和资源投入。 2. 提高效率 通过优先测试最关键的功能和最有可能出错的区域&#xff0c;更快地发现和修复重大缺陷&#xff0c;从…

idea无法识别jsp以及注释和格式化快捷键都无效

将下面的插件打开&#xff0c;idea便能识别jsp文件&#xff0c;并且能进行注释和格式化。

SDX12 定制使能secboot方法

SDX12 定制使能secboot方法 1. 镜像签名列表2 证书制作步骤3. 客制化秘钥证书4 调试验证 主要介绍SDX12平台定制秘钥使能secboot的具体操作流程和注意事项。 1. 镜像签名列表 如下表所示&#xff0c;表中是软件版本中的所有镜像并标出哪些镜像需要签名。 序号镜像文件是否签名…

数塔问题【java】

[实验题目3] 使用动态规划法解决数塔问题。 问题描述&#xff1a;从数塔的顶层出发&#xff0c;在每一个结点可以选择向左走或向右走&#xff0c;一直走到最底层&#xff0c;要求找出一条路径&#xff0c;使得路径上的数值和最大。 一个示例&#xff1a; 核心思想&#xff1…