Java解析Excel之POI

Posted Loading ...

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java解析Excel之POI相关的知识,希望对你有一定的参考价值。

引入依赖:

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>4.0.1</version>
</dependency>

解析代码:

public static void main(String[] args) {

        // 【读取】------------------------------------------------------------
        // 从 template.xls 文件中读取数据,并保存到 ArrayList<Area> 中后打印输出。
        ArrayList<Area> list = new ArrayList<Area>();
        try {
            // 1、获取文件输入流
            InputStream inputStream = new FileInputStream("/Users/hrvy/temp/template.xls");
            // 2、获取Excel工作簿对象
            HSSFWorkbook workbook = new HSSFWorkbook(inputStream);
            // 3、得到Excel工作表对象
            HSSFSheet sheetAt = workbook.getSheetAt(0);
            // 4、循环读取表格数据
            for (Row row : sheetAt) {
                // 首行(即表头)不读取
                if (row.getRowNum() == 0) {
                    continue;
                }
                // 读取当前行中单元格数据,索引从0开始
                String country = row.getCell(0).getStringCellValue();
                String province = row.getCell(1).getStringCellValue();
                String city = row.getCell(2).getStringCellValue();

                Area area = new Area();
                area.setCountry(country);
                area.setProvince(province);
                area.setCity(city);
                list.add(area);
            }
            System.out.println(list.toString());
            // 5、关闭流
            workbook.close();
        } catch (IOException e) {
            e.printStackTrace();
        }

        // 【写出】------------------------------------------------------------
        // 新建一个 template_copy.xls 文件,并将 ArrayList<Area> 中的数据写入 template_copy.xls 文件
        // 1.在内存中创建一个excel文件
        HSSFWorkbook workbook = new HSSFWorkbook();
        // 2.创建工作簿
        HSSFSheet sheet = workbook.createSheet();
        // 3.创建标题行
        HSSFRow titlerRow = sheet.createRow(0);
        titlerRow.createCell(0).setCellValue("国家copy");
        titlerRow.createCell(1).setCellValue("省份copy");
        titlerRow.createCell(2).setCellValue("城市copy");
        // 4.遍历数据,创建数据行
        for (Area area : list) {
            // 获取最后一行的行号
            int lastRowNum = sheet.getLastRowNum();
            // 添加新行
            HSSFRow dataRow = sheet.createRow(lastRowNum + 1);
            dataRow.createCell(0).setCellValue(area.getCountry());
            dataRow.createCell(1).setCellValue(area.getProvince());
            dataRow.createCell(2).setCellValue(area.getCity());
        }
        // 5.创建文件名
        String fileName = "template_copy.xls";
        // 6.获取输出流对象
        OutputStream outputStream;
        try {
            outputStream = new FileOutputStream("/Users/hrvy/temp/" + fileName);
            // 7.写出文件,关闭流
            workbook.write(outputStream);
            workbook.close();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        
    }

 

 

参照:

https://www.cnblogs.com/gdwkong/p/8669220.html

以上是关于Java解析Excel之POI的主要内容,如果未能解决你的问题,请参考以下文章

JAVA Apache POI 之sax 解析10万级大数量数据

JAVA Apache POI 之sax 解析10万级大数量数据

java使用POI解析2007以上的Excel表格

java使用poi读取excel时,电话号码变成了科学计数法,整数变成double,怎么改过来

Java对Excel解析(求助)

Java用POI解析excel并获取所有单元格数据