今天在开发中遇到用户列表导入导出的功能实现,这里了解到使用POI函数库可以完成此任务!特此记录一下

POI

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

  • HSSF:提供读写Excel格式档案的功能。Excel2003
  • XSSF:提供读写OOXML格式档案的功能。Excel2007
  • HWPF:提供读写Word文档的功能。
  • HSLF:提供读写PPT的功能。
  • HDGF:提供读写Visio格式档案的功能。

上面提及到的五个对象分别操作不同文件。
这里只测试了Excel读写相关,剩下的只需要修改文件后缀名和指定对象即可。

相关依赖

创建完项目后,首先需要引入POI的相关依赖。

 <dependencies>
<!-- xls -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.9</version>
</dependency>
<!-- xlsx -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.9</version>
</dependency>
<!-- test -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
</dependencies>

将数据保存到Excel2003

步骤
1、创建workbook对象,workbook是接口,实现类指定要操作的对象,例如要操作的文件是Excel2003就创建的是HSSFWorkbook,如果操作的是Excel2007那就创建XSSFWorkbook

2、创建Sheet对象,Sheet具体指的就是哪张表

3、创建Row,指明要将写入的数据放在第几行
4、创建Cell,指明将数据写在第几列,也就是第几个单元格
5、最后创建输出流,将内存中的数据持久化

/**
* 向Excel2003版本中写入数据
*/
@Test
public void writeTest03() throws IOException { //1、创建Workbook
Workbook workbook = new HSSFWorkbook();
//2、创建sheet,默认名字是sheet1,sheet2...
Sheet sheet = workbook.createSheet("会员列表");
//3、创建row 参数是0代表第1行,参数是1代表第二行...
Row row1 = sheet.createRow(0);
//4、创建cell 第0列
Cell cell = row1.createCell(0);
//5、在cell中填充数据
cell.setCellValue("datao");
//6、向文件中写入数据,以上步骤都是在内存中完成的,想要将文件持久化到磁盘需要文件输出流
FileOutputStream outputStream = new FileOutputStream("E:\\1.xls");
workbook.write(outputStream);
//7、关闭流
outputStream.close(); }

将数据保存在Excel2007

步骤和上面的基本一样,只是workbook的实现类不同,保存的文件名后缀不同。

public void writeTest07() throws IOException {

        //1、创建Workbook
Workbook workbook = new XSSFWorkbook();
//2、创建sheet,默认名字是sheet1,sheet2...
Sheet sheet = workbook.createSheet("用户列表");
//3、创建row 参数是0代表第1行,参数是1代表第二行...
Row row1 = sheet.createRow(0);
//4、创建cell 第0列
Cell cell = row1.createCell(0);
//5、在cell中填充数据
cell.setCellValue("贝姐");
//6、向文件中写入数据,以上步骤都是在内存中完成的,想要将文件持久化到磁盘需要文件输出流,注意保存到文件的后缀名,03版本的Excel文件是以.xls结尾
//excel2007版本是以.xlsx结尾
FileOutputStream outputStream = new FileOutputStream("E:\\2.xlsx");
workbook.write(outputStream);
//7、关闭流
outputStream.close();
}


写入大文件

  • 使用HSSFWorkbook写入数据有个缺点就是写入的数据是有限的,最大不能超过65535行,超过会写不进去,抛出异常,java.lang.IllegalArgumentException: Invalid row number (65536) outside allowable range (0..65535)
    他是先将内存中的数据一次性写入磁盘。

  • 如果使用XSSFWorkbook写入大数据时,虽然不会报错,但是他写入速度很慢。(当写入100万行数据时内存才会溢出)

  • 如果写入大文件,推荐使用SXSSFWorkbook,它可以写入100万条数据以上,并且写入速度很快,分段写入。
    SXSSFWorkbook官方的解释:实现“BigGridDemo”策略的流式XSSFWorkbook版本。这允许写入非常大的文件而不会耗尽内存,因为任何时候只有可配置的行部分被保存在内存中。
    请注意,仍然可能会消耗大量内存,这些内存基于您正在使用的功能,例如合并区域,注释…仍然只存储在内存中,因此如果广泛使用,可能需要大量内存。

从Excel中读取

  1. 创建文件输出入流
  2. 创建workbook构造参数传入输入流
  3. 读取指定的sheet
  4. 根据sheet读取行
  5. 根据行读取单元格
  6. 输出结果
  7. 关闭输入流
//从Excel中读取值,并输出
@Test
public void read03Test() throws IOException {
//1、创建输入流,指定要读取的文件
InputStream inputStream = new FileInputStream("E:\\1.xls");
//2、创建workbook将输入流传过去
HSSFWorkbook hssfWorkbook = new HSSFWorkbook(inputStream);
//3、指定读取的sheet
HSSFSheet sheet = hssfWorkbook.getSheet("会员列表");
//4、获取指定行
HSSFRow row = sheet.getRow(0);
//5、获取指定cell
HSSFCell cell = row.getCell(0);
//6、从cell中也就是单元格中获取数据
String cellValue = cell.getStringCellValue();
//输出结果
System.out.println(cellValue);
//关闭输入流
inputStream.close();
}

Java向指定Excel写入读取数据的更多相关文章

  1. 从Excel中读取数据(python-xlrd)

    从Excel中读取数据(python-xlrd) 1.导入模块 import xlrd 2.打开Excel文件读取数据 data = xlrd.open_workbook('excelFile.xls ...

  2. .NET 5/.NET Core使用EF Core 5连接MySQL数据库写入/读取数据示例教程

    本文首发于<.NET 5/.NET Core使用EF Core 5(Entity Framework Core)连接MySQL数据库写入/读取数据示例教程> 前言 在.NET Core/. ...

  3. 在实现从excel中读取数据作为接口参数遇到的问题

    这个算我自己第一次使用python语言实现 一个功能 一.首先我们先要代码实现如何从excel上读取数据python实现还是比较简单的 1.我使用的是xlrd模块,我们先要安装这个包,这样我们才可以使 ...

  4. Java从.CSV文件中读取数据和写入

    .CSV文件是以逗号分割的数据仓储,读取数据时从每一行中读取一条数据元祖,也就是一条数据,再用字符分割的方式获取表中的每一个数据项. import java.io.BufferedReader;    ...

  5. 从Excel中读取数据并批量写入MySQL数据库(基于MySQLdb)

    一.Excel内容如下,现在需要将Excel中的数据全部写入的MySQL数据库中: 二.连接MySQL的第三方库使用的是“MySQLdb”,代码如下: # -*- coding:utf-8 -*-im ...

  6. Java怎样处理EXCEL的读取

    须要包:poi-3.5.jar.poi-ooxml-3.5.jar 实例: [java] view plaincopy public class ProcessExcel { private Work ...

  7. C#实现从EXCEL文件读取数据到SqlServer数据库

    用第三方组件:NPOI组件实现 先去官网:http://npoi.codeplex.com/下载需要引入dll(可以选择.net2.0或者.net4.0的dll),然后在网站中添加引用.使用 NPOI ...

  8. JAVA BufferedReader 类从标准输入读取数据

    1,从标准输入上建立输入流: BufferedReader localReader = new BufferedReader( new InputStreamReader(System.in)); S ...

  9. openxl模块从excel里面读取数据

    #excel读取数据 from openpyxl import load_workbook class Do_Excel: def __init__(self,file,work_space,inde ...

随机推荐

  1. nginx学习之——信号控制和配置

    一.信号控制 1)TERM, INT   Quick shutdown  \\麻溜停掉(暴力停止),一般不常用 // 启动和停止nginx 当前目录:/usr/local/bin/nginx 启动: ...

  2. STL—— 容器(vector)的数据写入、修改和删除

    1. 通过 push_back() 尾部增加一个元素 : vector 可以通过 "push_back " 写入数据,通过 push_back 可以将数据直接写入至 vector ...

  3. Mysql性能优化专栏

    1.  最大数据量 Mysql没有对单表的数据量大小做限制,单表的大小取决于操作系统对文件大小的限制. <阿里巴巴Java开发手册>中建议当单表的数据量大小超过500万行或者大于2GB时需 ...

  4. 前端魔法堂:可能是你见过最详细的WebWorker实用指南

    前言 JavaScript从使用开初就一直基于事件循环的单线程运行模型,即使是成功进军后端开发的Nodejs也没有改变这一模型.那么对于计算密集型的应用,我们必须创建新进程来执行运算,然后执行进程间通 ...

  5. 刚入坑之C#《方法》解说

    说好的用一周时间学方法,我都快耽误成两周了.原因就是跟着传智播客的课程做了个飞行棋项目,想要梳理其中的方法却把自己绕晕了.那接下来我先说一下我学到方法的内容,在最后献上飞行器项目的代码,当然是传智播客 ...

  6. fMRI数据分析学习笔记——常用工具

    背景 在学习fMRI数据处理的过程中,通过其他的资料看到了别人推荐的有用的fMRI数据处理软件和小插件,在此记录一下,以便后期慢慢学习使用. 1.NeuroImaging Analysis Kit ( ...

  7. 多任务-python实现-使用生成器完成多任务(2.1.14)

    @ 目录 1.注意 2. 代码 关于作者 1.注意 先定义函数,函数里面放一个yiled 主函数生成该对象 执行while循环 调用生成器对象的next 因为每次调用next,不会继续执行,从而 完成 ...

  8. XCTF EasyHook

    无壳,使用IDA直接分析主函数 逻辑很简单,问题的关键是Hook,题目也是EasyHook, 会发现在生成文件后,文件内容是被加密后的,那就怀疑加密函数参与Hook 动态调试一步步来看,先进入4012 ...

  9. SpringBoot从入门到精通教程(七)

    今天,我们继续讲SpringBoot整合Redis ,也就缓存,它将与我们的Springboot整合 Redis 简介 Redis 是当前比较热门的NOSQL系统之一,它是一个开源的使用ANSI c语 ...

  10. 无法获得VMCI驱动程序的版本:句柄无效 (亲测有效! )

    今天在学习Linux 的时候 启动VM时出现了这个问题, 搞了很久终于弄好了, 就写篇博客来记录一下,帮助一下大家,如果对大家有帮助,还请各位哥哥姐姐点个关注,你的支持就是我坚持下去的动力 ! 文章目 ...