使用POI操作Excel文件

每篇一句

坐观垂钓者,徒有羡鱼情 —— 唐 · 孟浩然《望洞庭湖赠张丞相》

什么是POI

Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。

结构:

  • HSSF - 提供读写Microsoft Excel格式档案的功能。
  • XSSF - 提供读写Microsoft Excel OOXML格式档案的功能。
  • HWPF - 提供读写Microsoft Word格式档案的功能。
  • HSLF - 提供读写Microsoft PowerPoint格式档案的功能。
  • HDGF - 提供读写Microsoft Visio格式档案的功能。

Maven依赖

<dependency>
  <groupId>org.apache.poi</groupId>
  <artifactId>poi</artifactId>
  <version>3.14</version>
</dependency>
<dependency>
  <groupId>org.apache.poi</groupId>
  <artifactId>poi-ooxml</artifactId>
  <version>3.14</version>
</dependency>

最常用的就是操作Excel文件,下面是我对Excel文件的读写操作

读取文件

package com.zuoyueer.utils2;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.web.multipart.MultipartFile;

import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.List;

/**
 * @author Zuoyueer
 * Date: 2019/12/10
 * Time: 21:45
 * @projectName health_parent
 * @description: 自己写工具类:读取Excel文件,并解析返回List<String[]>
 */
public class PoiUtils {
    //Excel 2003的文件后缀
    private final static String XLS = "xls";
    //Excel 2007的文件后缀
    private final static String XLSX = "xlsx";
    //日期格式
    private final static String DATE_FORMAT = "yyyy/MM/dd";

    /**
     * 读入excel文件,解析后返回
     * @param file
     */
    public static List<String[]> readExcel(MultipartFile file) throws IOException {
        //检查文件
        checkFile(file);
        //获得工作簿对象
        Workbook workBook = getWorkBook(file);
        //创建返回对象,把每行的数据作为一个数组, 所有的行数组再封装到List集合中
        List<String[]> list = new ArrayList<>();
        if (workBook != null) {
            //遍历工作表对象
            for (int sheetNum = 0; sheetNum < workBook.getNumberOfSheets(); sheetNum++) {
                //获取工作表对象
                Sheet sheet = workBook.getSheetAt(sheetNum);
                //如果是空就跳过该sheet的遍历
                if (sheet == null) {
                    continue;
                }
                //获取当前sheet的开始行号
                int firstRowNum = sheet.getFirstRowNum();
                //获取当前sheet的最后行号
                int lastRowNum = sheet.getLastRowNum();
                //循环遍历当前sheet表的全部行(除了第一行)
                for (int rowNum = firstRowNum + 1; rowNum <= lastRowNum; rowNum++) {
                    //获得行
                    Row row = sheet.getRow(rowNum);
                    //如果是空,就跳过该行的遍历
                    if (row == null) {
                        continue;
                    }
                    //每一行开始的列号
                    int firstCellNum = row.getFirstCellNum();
                    //每一行结束的列号
                    int lastCellNum = row.getPhysicalNumberOfCells();
                    //每一行都创建一个数组,来存放当前行的全部列数据
                    String[] cells = new String[row.getPhysicalNumberOfCells()];
                    //遍历当前行的全部列
                    for (int cellNum = firstCellNum; cellNum < lastCellNum; cellNum++) {
                        //获取列
                        Cell cell = row.getCell(cellNum);
                        //列的数据存储到数组中
                        cells[cellNum] = getCellValue(cell);
                    }
                    //把每一行的全部数据封装到list集合中
                    list.add(cells);
                }
            }
            workBook.close();
        }
        return list;
    }

    /**
     * 检查文件
     */
    public static void checkFile(MultipartFile file) throws IOException {
        //判断文件是否存在
        if (file == null) {
            throw new FileNotFoundException("文件不存在");
        }
        //获取文件名
        String originalFilename = file.getOriginalFilename();
        //判断文件后缀名
        if (!originalFilename.endsWith(XLS) && !originalFilename.endsWith(XLSX)) {
            throw new IOException(originalFilename + "不是Excel文件");
        }
    }

    /**
     * 获取工作簿对象
     * ------------------------
     * 因为版本不同,Workbook接口的实现类不同, 创建的对象也不同
     * ----------------------
     * 创建对象的时候使用文件输入流作为参数
     */
    public static Workbook getWorkBook(MultipartFile file) {
        //获取文件名
        String originalFilename = file.getOriginalFilename();
        //创建一个工作簿对象,表示整个Excel对象
        Workbook workbook = null;
        try {
            //获取文件的io流
            InputStream inputStream = file.getInputStream();
            //根据文件后缀名不同, 获取不同的工作簿对象
            if (originalFilename.endsWith(XLS)) {
                //2003
                workbook = new HSSFWorkbook(inputStream);
            } else if (originalFilename.endsWith(XLSX)) {
                //2007
                workbook = new XSSFWorkbook(inputStream);
            }
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
        return workbook;
    }

    //对数据做类型转换
    public static String getCellValue(Cell cell) {
        String cellValue = "";
        if (cell == null) {
            return cellValue;
        }
        //如果当前单元格的内容是日期类型,需要特殊处理
        String dataFormatString = cell.getCellStyle().getDataFormatString();
        if ("m/d/yy".equals(dataFormatString)) {
            cellValue = new SimpleDateFormat(DATE_FORMAT).format(cell.getDateCellValue());
            return cellValue;
        }
        //把数字当做String来读,避免出现1读取成1.0的情况
        if (Cell.CELL_TYPE_NUMERIC == cell.getCellType()) {
            cell.setCellType(Cell.CELL_TYPE_STRING);
        }
        //判断数据类型
        switch (cell.getCellType()) {
            case Cell.CELL_TYPE_NUMERIC: //数字
                cellValue = String.valueOf(cell.getNumericCellValue());
                break;
            case Cell.CELL_TYPE_STRING://字符串
                cellValue = String.valueOf(cell.getStringCellValue());
                break;
            case Cell.CELL_TYPE_BOOLEAN://Boolean
                cellValue = String.valueOf(cell.getBooleanCellValue());
                break;
            case Cell.CELL_TYPE_FORMULA://公式
                cellValue = String.valueOf(cell.getCellFormula());
                break;
            case Cell.CELL_TYPE_BLANK://空格
                cellValue = "";
                break;
            case Cell.CELL_TYPE_ERROR:
                cellValue = "非法字符";
                break;
            default:
                cellValue = "为知类型";
                break;
        }
        return cellValue;
    }
}

写输入到Excel文件中

 /**
     * 向Excel文件写入数据
     */
    @Test
    public void method3() throws Exception {
        //创建工作簿
        XSSFWorkbook workbook = new XSSFWorkbook();
        //创建工作表
        XSSFSheet sheet = workbook.createSheet("学生名单");
        //创建行
        XSSFRow row = sheet.createRow(0);
        //创建列,并设置内容
        row.createCell(0).setCellValue("姓名");
        row.createCell(1).setCellValue("性别");
        row.createCell(2).setCellValue("地址");
        XSSFRow row2 = sheet.createRow(1);
        row2.createCell(0).setCellValue("张三");
        row2.createCell(1).setCellValue("男");
        row2.createCell(2).setCellValue("深圳");
        XSSFRow row3 = sheet.createRow(2);
        row3.createCell(0).setCellValue("李四");
        row3.createCell(1).setCellValue("男");
        row3.createCell(2).setCellValue("北京");
        //通过输出流对象写到磁盘
        FileOutputStream fos = new FileOutputStream("F:/student.xlsx");
        workbook.write(fos);
        fos.flush();
        fos.close();
        workbook.close();
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值