poi方式写入数据到Excel

简介: 在java数据库编程中,常常会用到向excel中读写数据,一方面可以将数据从数据库导出到Excel,进行数据展示,另一方面可以批量的向数据库插入多条数据,这对于软件开发是必不可少的,今天先介绍如何使用java向excel中写入数据,这里以2003版本的excel版本为例,分享我的实战经验。(在后续的经验中会介绍excel数据导出,敬请浏览)工具/原料eclipse, java poi

在java数据库编程中,常常会用到向excel中读写数据,一方面可以将数据从数据库导出到Excel,进行数据展示,另一方面可以批量的向数据库插入多条数据,这对于软件开发是必不可少的,今天先介绍如何使用java向excel中写入数据,这里以2003版本的excel版本为例,分享我的实战经验。(在后续的经验中会介绍excel数据导出,敬请浏览)

工具/原料

  • eclipse, java poi的jar包

方法/步骤

  1. 1

    导入POI的jar包

    新建一个项目,在根目录在新建一个lib文件夹,将jar包复制粘贴到lib文件夹后,右键将其添加到项目的build path中,最后的结果如图所示:

  2. 2

    编写java类,新建一个实体类,比如我们要导出数据库的有关电脑的信息,那么就建一个Computer实体类,代码如下:

    package com.qiang.poi;

    public class Computer {

     private int id;

     private String name;

     private String description;

     private double price;

     private double credit;

     public int getId() {

      return id;

     }

     public Computer(int id, String name, String description, double price,

       double credit) {

      super();

      this.id = id;

      this.name = name;

      this.description = description;

      this.price = price;

      this.credit = credit;

     }

     public void setId(int id) {

      this.id = id;

     }

     public String getName() {

      return name;

     }

     public void setName(String name) {

      this.name = name;

     }

     public String getDescription() {

      return description;

     }

     public void setDescription(String description) {

      this.description = description;

     }

     public double getPrice() {

      return price;

     }

     public void setPrice(double price) {

      this.price = price;

     }

     public double getCredit() {

      return credit;

     }

     public void setCredit(double credit) {

      this.credit = credit;

     }

    }

  3. 3

    新建一个写入excel的方法,如write2excel,参数可以后面边写边决定(站在一个不熟悉POI的角度)

    public static void write2Excel(){}                                 

  4. 4

    创建操作Excel的HSSFWorkbook对象

    HSSFWorkbook excel= new HSSFWorkbook();

  5. 5

    创建HSSFSheet对象

    Excel中的一个sheet(工作表)对应着java中的一个HSSFSheet对象,利用HSSFWorkbook对象可以创建一个HSSFSheet对象

        如:创建一个sheet名为computer的excel  

    HSSFSheet sheet = excel.createSheet("computer");

  6. 6

    创建第一行标题信息的HSSFRow对象

    我们都知道excel是表格,即由一行一行组成的,那么这一行在java类中就是一个HSSFRow对象,我们通过HSSFSheet对象就可以创建HSSFRow对象

        如:创建表格中的第一行(我们常用来做标题的行)  HSSFRow firstRow = sheet.createRow(0); 注意下标从0开始

  7. 7

    创建标题行中的HSSFCell数组

    当然,excel中每一行是由若干个单元格,我们常称为cell,它对应着java中的HSSFCell对象

        如:创建5个单元格       HSSFCell cells[] = new HSSFCell[5]; 

    //假设我们一行有五列数据

  8. 8

    创建标题数据,并通过HSSFCell对象的setCellValue()方法对每个单元格进行赋值

    既然单元格都准备好了,那最后是不是该填充数据了呀。对的,没错。填充数据之前,得把数据准备好吧,

        数据:String[] titles = new String[]{"id","name","description","price","credit"};

        插入一句话: 在这个时代,能让机器做的,尽量不让人来做,记住这句话。

        好的,继续。现在就通过for循环来填充第一行标题的数据

    for (int i = 0; i < 5; i++) {

       cells[0] = firstRow.createCell(i);

       cells[0].setCellValue(titles[i]);

      }

  9. 9

    数据分析

    第一行标题栏创建完毕后,就准备填充我们要写入的数据吧,在java中,面向对象给我们带来的好处在这里正好体现了,没错

    把要填写的数据封装在对象中,即一行就是一个对象,n行就是一个对象列表嘛,好的,走起。

    创建对象Computer,私有属性id,name,description,price,credit,以及各属性的setter和getter方法,如步骤二所示。

    假设我们要写入excel中的数据从数据库查询出来的,最后就生成了一个List<Computer>对象computers

  10. 10

    数据写入

    具体数据有了,又该让机器帮我们干活了,向excel中写入数据。

    for (int i = 0; i < computers.size(); i++) {

       HSSFRow row = sheet.createRow(i + 1);

       Computer computer = computers.get(i);

       HSSFCell cell = row.createCell(0);

       cell.setCellValue(computer.getId());

       cell = row.createCell(1);

       cell.setCellValue(computer.getName());

       cell = row.createCell(2);

       cell.setCellValue(computer.getDescription());

       cell = row.createCell(3);

       cell.setCellValue(computer.getPrice());

       cell = row.createCell(4);

       cell.setCellValue(computer.getCredit());

      }

  11. 11

    将数据真正的写入excel文件中

    做到这里,数据都写好了,最后就是把HSSFWorkbook对象excel写入文件中了。

            OutputStream out = null;

            try {

                out = new FileOutputStream(file);

                excel.write(out);

                out.close();

            } catch (FileNotFoundException e) {

                e.printStackTrace();

            } catch (IOException e) {

                // TODO Auto-generated catch block

                e.printStackTrace();

            }

            System.out.println("数据已经写入excel"); //温馨提示

  12. 12

    看看我的main方法吧

    public static void main(String[] args) throws IOException {

      File file = new File("test1.xls");

      if(!file.exists()){

       file.createNewFile();

      }

      List<Computer> computers = new ArrayList<Computer>();

      computers.add(new Computer(1,"宏碁","笔记本电脑",3333,9.0));

      computers.add(new Computer(2,"苹果","笔记本电脑,一体机",8888,9.6));

      computers.add(new Computer(3,"联想","笔记本电脑,台式机",4444,9.3));

      computers.add(new Computer(4, "华硕", "笔记本电脑,平板电脑",3555,8.6));

      computers.add(new Computer(5, "注解", "以上价格均为捏造,如有雷同,纯属巧合", 1.0, 9.9));

      write2excel(computers, file);

     }

  13. 13

    工程目录及执行main方法后的test1.xls数据展示

  14. 14

    源码分享,computer就不贴了

    package com.qiang.poi;

    import java.io.File;

    import java.io.FileNotFoundException;

    import java.io.FileOutputStream;

    import java.io.IOException;

    import java.io.OutputStream;

    import java.util.ArrayList;

    import java.util.List;

    import org.apache.poi.hssf.usermodel.HSSFCell;

    import org.apache.poi.hssf.usermodel.HSSFRow;

    import org.apache.poi.hssf.usermodel.HSSFSheet;

    import org.apache.poi.hssf.usermodel.HSSFWorkbook;

    public class ReadExcel {

     public static void main(String[] args) throws IOException {

      File file = new File("test1.xls");

      if(!file.exists()){

       file.createNewFile();

      }

      List<Computer> computers = new ArrayList<Computer>();

      computers.add(new Computer(1,"宏碁","笔记本电脑",3333,9.0));

      computers.add(new Computer(2,"苹果","笔记本电脑,一体机",8888,9.6));

      computers.add(new Computer(3,"联想","笔记本电脑,台式机",4444,9.3));

      computers.add(new Computer(4, "华硕", "笔记本电脑,平板电脑",3555,8.6));

      computers.add(new Computer(5, "注解", "以上价格均为捏造,如有雷同,纯属巧合", 1.0, 9.9));

      write2excel(computers, file);

     }

     

     public static void write2excel(List<Computer> computers,File file) {

      HSSFWorkbook excel = new HSSFWorkbook();

      HSSFSheet sheet = excel.createSheet("computer");

      HSSFRow firstRow = sheet.createRow(0);

      HSSFCell cells[] = new HSSFCell[5];

      String[] titles = new String[] { "id", "name", "description", "price",

        "credit" };

      for (int i = 0; i < 5; i++) {

       cells[0] = firstRow.createCell(i);

       cells[0].setCellValue(titles[i]);

      }

      for (int i = 0; i < computers.size(); i++) {

       HSSFRow row = sheet.createRow(i + 1);

       Computer computer = computers.get(i);

       HSSFCell cell = row.createCell(0);

       cell.setCellValue(computer.getId());

       cell = row.createCell(1);

       cell.setCellValue(computer.getName());

       cell = row.createCell(2);

       cell.setCellValue(computer.getDescription());

       cell = row.createCell(3);

       cell.setCellValue(computer.getPrice());

       cell = row.createCell(4);

       cell.setCellValue(computer.getCredit());

      }

            OutputStream out = null;

            try {

                out = new FileOutputStream(file);

                excel.write(out);

                out.close();

            } catch (FileNotFoundException e) {

                e.printStackTrace();

            } catch (IOException e) {

                e.printStackTrace();

            }

     }

    }

目录
相关文章
|
7月前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####
1106 10
|
2月前
|
存储 安全 大数据
网安工程师必看!AiPy解决fscan扫描数据整理难题—多种信息快速分拣+Excel结构化存储方案
作为一名安全测试工程师,分析fscan扫描结果曾是繁琐的手动活:从海量日志中提取开放端口、漏洞信息和主机数据,耗时又易错。但现在,借助AiPy开发的GUI解析工具,只需喝杯奶茶的时间,即可将[PORT]、[SERVICE]、[VULN]、[HOST]等关键信息智能分类,并生成三份清晰的Excel报表。告别手动整理,大幅提升效率!在安全行业,工具党正碾压手动党。掌握AiPy,把时间留给真正的攻防实战!官网链接:https://www.aipyaipy.com,解锁更多用法!
|
5月前
|
分布式计算 Hadoop 大数据
从Excel到Hadoop:数据规模的进化之路
从Excel到Hadoop:数据规模的进化之路
90 10
|
7月前
|
存储 Java easyexcel
招行面试:100万级别数据的Excel,如何秒级导入到数据库?
本文由40岁老架构师尼恩撰写,分享了应对招商银行Java后端面试绝命12题的经验。文章详细介绍了如何通过系统化准备,在面试中展示强大的技术实力。针对百万级数据的Excel导入难题,尼恩推荐使用阿里巴巴开源的EasyExcel框架,并结合高性能分片读取、Disruptor队列缓冲和高并发批量写入的架构方案,实现高效的数据处理。此外,文章还提供了完整的代码示例和配置说明,帮助读者快速掌握相关技能。建议读者参考《尼恩Java面试宝典PDF》进行系统化刷题,提升面试竞争力。关注公众号【技术自由圈】可获取更多技术资源和指导。
|
9月前
|
数据处理 Python
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
这篇文章介绍了如何使用Python读取Excel文件中的数据,处理后将其保存为txt、xlsx和csv格式的文件。
441 3
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
|
9月前
|
easyexcel Java UED
SpringBoot中大量数据导出方案:使用EasyExcel并行导出多个excel文件并压缩zip后下载
在SpringBoot环境中,为了优化大量数据的Excel导出体验,可采用异步方式处理。具体做法是将数据拆分后利用`CompletableFuture`与`ThreadPoolTaskExecutor`并行导出,并使用EasyExcel生成多个Excel文件,最终将其压缩成ZIP文件供下载。此方案提升了导出效率,改善了用户体验。代码示例展示了如何实现这一过程,包括多线程处理、模板导出及资源清理等关键步骤。
|
9月前
|
前端开发 JavaScript Java
导出excel的两个方式:前端vue+XLSX 导出excel,vue+后端POI 导出excel,并进行分析、比较
这篇文章介绍了使用前端Vue框架结合XLSX库和后端结合Apache POI库导出Excel文件的两种方法,并对比分析了它们的优缺点。
2211 0
|
9月前
|
数据采集 存储 JavaScript
自动化数据处理:使用Selenium与Excel打造的数据爬取管道
本文介绍了一种使用Selenium和Excel结合代理IP技术从WIPO品牌数据库(branddb.wipo.int)自动化爬取专利信息的方法。通过Selenium模拟用户操作,处理JavaScript动态加载页面,利用代理IP避免IP封禁,确保数据爬取稳定性和隐私性。爬取的数据将存储在Excel中,便于后续分析。此外,文章还详细介绍了Selenium的基本设置、代理IP配置及使用技巧,并探讨了未来可能采用的更多防反爬策略,以提升爬虫效率和稳定性。
508 4
|
11月前
|
关系型数据库 MySQL Shell
不通过navicat工具怎么把查询数据导出到excel表中
不通过navicat工具怎么把查询数据导出到excel表中
109 0
|
10月前
|
数据采集 存储 数据挖掘
使用Python读取Excel数据
本文介绍了如何使用Python的`pandas`库读取和操作Excel文件。首先,需要安装`pandas`和`openpyxl`库。接着,通过`read_excel`函数读取Excel数据,并展示了读取特定工作表、查看数据以及计算平均值等操作。此外,还介绍了选择特定列、筛选数据和数据清洗等常用操作。`pandas`是一个强大且易用的工具,适用于日常数据处理工作。

热门文章

最新文章