java使用poi操作excel表格的功能实现

入门案例:

从Excel文件读取数据
1:新建excel表格(名称:HelloWord):
在这里插入图片描述
表格地址:C:\Users\MrFan\Desktop\helloWord.xlsx
2:引入依赖 :

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

代码示例: 读取单元格内容

 public static void main(String[] args) throws IOException {
        //根据目录  创建一个工作薄对象
        XSSFWorkbook workbook = new XSSFWorkbook("C:\\Users\\MrFan\\Desktop\\helloWord.xlsx");
        //根据工作薄  获取到工作表  传入工作表的索引 第几个 工作表
        XSSFSheet sheetAt = workbook.getSheetAt(0);
        //根据工作表获取到行
        for (Row row : sheetAt) {
            //获取单元格
            for (Cell cell : row) {
                //获取单元格里的内容
                String stringCellValue = cell.getStringCellValue();
                //打印
                System.out.println(stringCellValue);
            }
        }

    }

结果:

空山
新雨后
天气
晚来秋

代码示例:向单元格里写入

  public static void main(String[] args) throws IOException {
        //创建工作薄
        XSSFWorkbook workbook = new XSSFWorkbook();
        //创建工作表,并通过有参的构造方法指定工作表名称
        XSSFSheet sheet = workbook.createSheet("诗几句");
        //创建行
        XSSFRow row = sheet.createRow(0);
        //创建单元格,指定索引的方式
        row.createCell(0).setCellValue("空山新雨后");
        row.createCell(1).setCellValue("天气晚来秋");

        //创建行  第二行
        XSSFRow row1 = sheet.createRow(1);
        //创建单元格,指定索引的方式
        row1.createCell(0).setCellValue("不识南朝今日雨");
        row1.createCell(1).setCellValue("路上行人是几朝");

        //输出流对象
        FileOutputStream fileOutputStream = new FileOutputStream("C:\\Users\\MrFan\\Desktop\\诗几首.xlsx");
        //调用工作薄的写出方法,并传入流对象
        workbook.write(fileOutputStream);
        //将内容进行刷新,并且释放资源
        fileOutputStream.flush();
        fileOutputStream.close();
        System.out.println("写入成功");

    }

输出示例:

写入成功

在这里插入图片描述
实战练习:
需求

  1. 读取excel数据到数据库
  2. 将数据库数据写入excel
  3. 增加样式

准备工作:
新建一个excel表格

在这里插入图片描述
创建一个与表格数据一致的实体类

//商品表
public class Product {
    //商品编号
    private Integer pid;
    //商品名称
    private String  pname;
    //商品价格
    private BigDecimal price;
    //商品库存
    private Integer pstock;
    //get/set方法

核心逻辑

package com.itFan.Excel;

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

import java.io.FileOutputStream;
import java.io.IOException;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class ProductExcel {
    public static void main(String[] args) throws IOException {
        //使用键盘录入白模拟用户操作
        Scanner scanner = new Scanner(System.in);
        System.out.println("请选择您要进行的操作,1-导入,2-导出");
        int num = scanner.nextInt();
        if (num == 1) {
            //进行导入操作,读取表格中的数据,并写入到数据库
            System.out.println("请输入您要读取的文件位置,不包含空格");
            String path = scanner.next();
            //调用读的方法
            List<Product> read = ProductExcel.read(path);
            //调用与数据库的对接方法insert,插入数据库 ===  自己完成哦


        } else if (num == 2) {
            //进行导出操作,读取数据库中的数据,并写出到表格中
            //1:读取数据  用sql 查出Product对象  是个ProductList集合
            //跟据业务表添加查询逻辑==========自己完成哦
            
            //2:写出表格
            System.out.println("请输入要写入的文档位置");
            String path = scanner.next();
            //调用写的方法
            List<Product> write = write(productList, path);
            System.out.println("数据已经成功从数据库写出到文件");
        }
        }
    //读取工作 表的操作
    private static List<Product> read(String path) throws IOException {
        //获取工作薄
        XSSFWorkbook workbook = new XSSFWorkbook(path);
        //获取工作表
        XSSFSheet sheetAt = workbook.getSheetAt(0);
        //定义商品返回对象
        ArrayList<Product> products = new ArrayList<>();
        //获取行 先获取行数  进行遍历  表中第一行的表单目录  在数据库中对应字段名  所以不需要读取
        //最后的行数
        int lastRowNum = sheetAt.getLastRowNum();
        for (int i = 1; i < lastRowNum; i++) {
            XSSFRow row = sheetAt.getRow(i);
            if (row != null) {
                //每一行数据就相当于以及各商品对象
                ArrayList<Object> list = new ArrayList<>();
                //获取单元格
                for (Cell cell : row) {
                    if (cell != null) {
                        //获取数据
                        //为了防止类型异常,先全部设为String类型
                        cell.setCellType(CellType.STRING);
                        String stringCellValue = cell.getStringCellValue();
                        if (stringCellValue != null && stringCellValue.trim().length()>0) {
                            list.add(stringCellValue);
                        }
                    }
                }
                if (list.size() > 0) {
                    //将表里的值 封装给商品对象 赋值给数据库里的值
                    products = new Product(Integer.parseInt(list.get(0)), list.get(1), Double.parseDouble(list.get(2)), Integer.parseInt(list.get(3)));
                }
            }
        }
        return products;
    }

    //写出到excel表中
    //读取工作 表的操作
    private static List<Product> write(List<Product> productList,String path) throws IOException {
        //创建工作铺
        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("商品单价(单位:元/斤)");
        row.createCell(3).setCellValue("商品库存(单位:吨)");
        for (int i = 0; i <productList.size(); i++) {
            //获取每次的行数
            XSSFRow row1 = sheet.createRow(i + 1);
            //给每个单元格赋值
            row1.createCell(0).setCellValue(ProductList.get(i).getPid());
            row1.createCell(1).setCellValue(ProductList.get(i).getPname());
            row1.createCell(2).setCellValue(ProductList.get(i).getPrice());
            row1.createCell(3).setCellValue(ProductList.get(i).getPstock());

        }
      //创建一个文件输出流  将文件输出
        FileOutputStream fileOutputStream = new FileOutputStream(path);
        //写出文件
        workbook.write(fileOutputStream);
        //将流中的数据刷新到磁盘中
        fileOutputStream.flush();
        //释放资源
        fileOutputStream.close();
  }
}


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值