poi excel文档生成与读取

阿帕奇poi excel文档操作

    • 1. introduce
    • 2. 轮子
    • 3. demo 以九九乘法表为例
      • 3.1 xls的生成
      • 3.2 xlsx的生成
      • 3.3 读取xlsx

1. introduce

  1. poi是什么
    答:用于excel的操作的,可以对集合,map进行操作生成对应的excel文档。做报表。

  2. 对应的iText是pdf操作的

  3. excel的两种版本

    1. 1997~2003版本的
    2. 2003版本的
      区别:后缀名不同。某w*s就是03的。。

      xls用老版本的excel和新版本的excel软件都能打开。
      而新版本的excel文件不会向下兼容。

2. 轮子

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

3. demo 以九九乘法表为例

3.1 xls的生成

   /*** 给定excel文件名 和 excel文档 生成excel文件* @param excelFileName* @param wb*/void createExcelFile(String excelFileName, Workbook wb) {// 生成文件,字节流输出File file = new File(excelFileName);OutputStream out = null;try {out = new FileOutputStream(file);try {wb.write(out);} catch (IOException e) {e.printStackTrace();}} catch (FileNotFoundException e) {e.printStackTrace();} finally {if (out != null) {try {out.close();} catch (IOException e) {e.printStackTrace();}}}}@Test/*** 生成xls的excel文档 97~03 年*/public void test2() {// 生成空白文档HSSFWorkbook hssfWorkbook = new HSSFWorkbook();// 生成sheet页HSSFSheet sheet1 = hssfWorkbook.createSheet("sheet page1");// 行for (int i = 0; i < 9; i++) {// 创建行HSSFRow row = sheet1.createRow(i);// 列for (int j = 0; j <= i; j++) {// 创建单元格HSSFCell cell = row.createCell(j);String res = (i + 1) + " * " + (j + 1) + " = " + (i + 1) * (j + 1);// 设置单元格内容cell.setCellValue(res);}}createExcelFile("excel1.xls", hssfWorkbook);}

3.2 xlsx的生成

换了个api

    /*** 生成xlsx 的文档*/@Testpublic void test3() {// 空白文档XSSFWorkbook xssfSheets = new XSSFWorkbook();// sheet页1XSSFSheet sheet1 = xssfSheets.createSheet("sheet1");// 行for (int i = 0; i < 9; i++) {// 创建行XSSFRow row = sheet1.createRow(i);// 列for (int j = 0; j <= i; j++) {// 创建单元格XSSFCell cell = row.createCell(j);String res = (i + 1) + " * " + (j + 1) + " = " + (i + 1) * (j + 1);// 设置单元格内容cell.setCellValue(res);}}createExcelFile("excel2.xlsx", xssfSheets);}

3.3 读取xlsx

    /*** 利用poi读取xlsx文件*/@Testpublic void test4() {try {InputStream in = new FileInputStream(new File("excel2.xlsx"));// 获得excel文档try {XSSFWorkbook xfb = new XSSFWorkbook(in);// sheet 页XSSFSheet sheet = xfb.getSheetAt(0);// 最大行的下标int lastRowNum = sheet.getLastRowNum();for (int i = 0; i < lastRowNum; i++) {// 拿到每行XSSFRow row = sheet.getRow(i);// 最大单元的行下标short cellNum = row.getLastCellNum();// 遍历单元格for (int j = 0; j < cellNum; j++) {// 获得单元格XSSFCell cell = row.getCell(j);if (cell != null)System.out.print(cell + " ");}System.out.println();}} catch (IOException e) {e.printStackTrace();}} catch (FileNotFoundException e) {e.printStackTrace();}}

最后,轮子的都得是,会用改,然后会用就行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/420578.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

echarts生成图表

目录1. echarts是一个优秀的js绘图框架2. 如何使用echats框架绘图&#xff1f;3. 更多彩蛋1. echarts是一个优秀的js绘图框架 ECharts&#xff0c;一个使用 JavaScript 实现的开源可视化库&#xff0c;可以流畅的运行在 PC 和移动设备上&#xff0c;兼容当前绝大部分浏览器&…

HDU 1394 线段树or 树状数组~

Minimum Inversion Number   Description The inversion number of a given number sequence a1, a2, ..., an is the number of pairs (ai, aj) that satisfy i < j and ai > aj. For a given sequence of numbers a1, a2, ..., an, if we move the first m > 0 nu…

servlet,springmvc,springboot转发时页面静态资源404问题

目录不讨论静态资源过滤的问题。。。这个问题重定向不会404&#xff0c;因为重定向是找到了对应的页面&#xff0c;是浏览器决定的。 而转发在相同目录下转发会找到资源。但是从controller&#xff08;根目录&#xff09;里面转发到根目录的下面的目录&#xff0c;转发能过去&…

mysql数据库面试总结

mysql数据库相关1. 数据库事务的四个特性及含义2. 视图的作用&#xff0c;视图可以更改么2.1 什么是视图&#xff0c;作用3. drop,delete与truncate的区别4. 索引的工作原理及其种类5. 连接查询的种类6. 数据库范式7. 数据库优化的思路7.1 sql语句的优化7.2 数据库结构优化7.3 …

springboot, thymeleaf 教你快速搭建网站

目录项目结构国际化curd操作404页面拦截器地址&#xff1a; https://github.com/sevenyoungairye/spring-boot-study员工管理员系统&#xff0c;页面用html thymeleaf模板数据库用的是map集合&#xff0c;没用真实的数据库项目结构 国际化 默认中文 中文&#xff0c;英文切换…

springboot 整合druid

目录1. maven依赖2. yml配置3. druid配置类编写4. 后台性能监控https://github.com/sevenyoungairye/spring-boot-studydruid优点&#xff1a;提供性能监控&#xff0c;配置灵活丰富 1. maven依赖 <!-- mysql驱动 springboot内置 --><dependency><groupId>…

maven 项目管理和构建工具

mvn1. maven 是什么2. maven能解决什么问题3. maven 需要配置和下载4. 使用eclipse创建maven项目5. xml依赖配置 作用范围6. maven的常用命令1. maven 是什么 Maven 在美国是一个口语化的词语&#xff0c;代表专家、内行的意思&#xff0c; Maven是一个项目管理工具&#xff0…

大数据----基于sogou.500w.utf8数据的MapReduce编程

目录 一、前言二、准备数据三、编程实现3.1、统计出搜索过包含有“仙剑奇侠传”内容的UID及搜索关键字记录3.2、统计rank<3并且order>2的所有UID及数量3.3、上午7-9点之间&#xff0c;搜索过“赶集网”的用户UID3.4、通过Rank&#xff1a;点击排名 对数据进行排序 四、参…

springboot 与shiro整合

shiro~ shiro快速入门springboot 整合shiro核心目标清爽pom用户认证授权认证&#xff0c;与数据库交互shiro configuration核心controller 获取shiro 中的token页面控制功能的隐藏和显示https://github.com/sevenyoungairye/spring-boot-study/tree/main/springboot-shiro-07sh…

jvm内存设置

摘抄自&#xff1a;http://www.cnblogs.com/fyj218/archive/2011/07/19/2110570.html 在eclipse根目录下打开eclipse.ini&#xff0c;默认内容为&#xff08;这里设置的是运行当前开发工具的JVM内存分配&#xff09;&#xff1a;-vmargs-Xms40m-Xmx256m-vmargs表示以下为虚拟机…

swagger接口文档使用

swagger接口文档一&#xff0c;swagger简介前后端分离swagger 诞生二&#xff0c;springboot集成swagger依赖编写helloworld接口配置swagger > config 配置类测试运行三&#xff0c;配置swaggerswagger 配置扫描接口如何做到只在生产环境中启动swagger&#xff1f;配置api文…

maven传递依赖

目录1. 依赖传递2. 什么是依赖冲突3. 怎么解决4. 项目聚合maven是一个项目管理的工具&#xff0c;从项目的构建到项目开发&#xff0c;再到项目的测试&#xff0c;项目上线&#xff0c;都可一键管理。1. 那么&#xff0c;还有maven是如何管理项目中所用到的jar版本冲突&#xf…

使用apache FileUtils下载文件

目录工具代码实现测试工具 <dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.5</version></dependency>或者 https://mvnrepository.com/artifact/commons-io/commons-io/2.7 然后放…

springmvc,spring,hibernate5.0整合

目录1. pom依赖2. web.xml3. spring核心配置文件3.1 jdbc配置信息3.2 sping 配置文件4. 实体映射5. 项目结构5.1 curd5.2 页面6. 测试1. spring版本 5.1.5 RELEASE 2. hibernate版本 5.3.9.Final 3. 数据源使用c3p0项目使用eclipse2017 maven构建, 完成学生的新增&#xff0c;…

MYSQL 查看表上索引的 1 方法

前期准备&#xff1a; create table T9(A int ,B text,C text,fulltext index fix_test_for_T8_B(B));#在定义表的时候加索引 create unique index ix_test_for_T8_A on T9(A);#加朴素索引 create fulltext index fix_test_for_T8_C on T9(C);#加全文索引 --------------------…

springmvc 结合ajax批量新增

目录1. 需要注意的问题2. 页面代码3. controller定义参数接收1. 需要注意的问题 mvc框架的处理日期问题ResponseBody响应对象是自定义对象&#xff0c;响应不是jsonResopnseBody响应自定义对象时&#xff0c;日期为是long类型的数结束数据方法的参数&#xff0c;该如何定义&am…